All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hubspot.singularity.scheduler.SingularityMesosHeartbeatChecker Maven / Gradle / Ivy

The newest version!
package com.hubspot.singularity.scheduler;

import com.google.inject.Inject;
import com.google.inject.name.Named;
import com.hubspot.singularity.SingularityMainModule;
import com.hubspot.singularity.config.SingularityConfiguration;
import com.hubspot.singularity.mesos.SingularityMesosScheduler;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicLong;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class SingularityMesosHeartbeatChecker extends SingularityLeaderOnlyPoller {
  private static final Logger LOG = LoggerFactory.getLogger(
    SingularityMesosHeartbeatChecker.class
  );

  private final SingularityConfiguration configuration;
  private final SingularityMesosScheduler mesosScheduler;
  private final AtomicLong lastHeartbeatTime;

  @Inject
  public SingularityMesosHeartbeatChecker(
    SingularityConfiguration configuration,
    SingularityMesosScheduler mesosScheduler,
    @Named(
      SingularityMainModule.LAST_MESOS_MASTER_HEARTBEAT_TIME
    ) AtomicLong lastHeartbeatTime
  ) {
    super(configuration.getCheckMesosMasterHeartbeatEverySeconds(), TimeUnit.SECONDS);
    this.configuration = configuration;
    this.mesosScheduler = mesosScheduler;
    this.lastHeartbeatTime = lastHeartbeatTime;
  }

  @Override
  public void runActionOnPoll() {
    if (!mesosScheduler.isRunning()) {
      LOG.debug(
        "Not checking for a Mesos heartbeat because we haven't subscribed with the Mesos Master yet."
      );
      return;
    }
    if (!mesosScheduler.getHeartbeatIntervalSeconds().isPresent()) {
      LOG.debug(
        "Not checking for a Mesos heartbeat because the Mesos Master didn't advertise a heartbeat interval."
      );
      return;
    }

    long millisSinceLastHeartbeat = System.currentTimeMillis() - lastHeartbeatTime.get();
    double missedHeartbeats =
      millisSinceLastHeartbeat /
      (mesosScheduler.getHeartbeatIntervalSeconds().get() * 1000);

    if (missedHeartbeats > configuration.getMaxMissedMesosMasterHeartbeats()) {
      LOG.error(
        "I haven't received a Mesos heartbeat in {}ms! Restarting mesos connection",
        millisSinceLastHeartbeat
      );
      mesosScheduler.reconnectMesos();
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy