YARN-7200. SLS generates a realtimetrack.json file but that file is missing the closing ']'. Contributed by Agshin Kazimli
This commit is contained in:
parent
630f8ddd2c
commit
6cd540e964
@ -159,6 +159,10 @@ public class SLSRunner extends Configured implements Tool {
|
||||
private TraceType inputType;
|
||||
private SynthTraceJobProducer stjp;
|
||||
|
||||
public static int getRemainingApps() {
|
||||
return remainingApps;
|
||||
}
|
||||
|
||||
public SLSRunner() throws ClassNotFoundException {
|
||||
Configuration tempConf = new Configuration(false);
|
||||
init(tempConf);
|
||||
@ -933,14 +937,14 @@ public class SLSRunner extends Configured implements Tool {
|
||||
|
||||
public static void decreaseRemainingApps() {
|
||||
remainingApps--;
|
||||
}
|
||||
|
||||
if (remainingApps == 0) {
|
||||
public static void exitSLSRunner() {
|
||||
LOG.info("SLSRunner tears down.");
|
||||
if (exitAtTheFinish) {
|
||||
System.exit(0);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void stop() throws InterruptedException {
|
||||
rm.stop();
|
||||
|
@ -54,6 +54,8 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.event.SchedulerEv
|
||||
import org.apache.hadoop.yarn.sls.SLSRunner;
|
||||
import org.apache.hadoop.yarn.sls.conf.SLSConfiguration;
|
||||
import org.apache.hadoop.yarn.util.resource.Resources;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import com.codahale.metrics.Timer;
|
||||
|
||||
@ -75,6 +77,9 @@ public class SLSCapacityScheduler extends CapacityScheduler implements
|
||||
private boolean metricsON;
|
||||
private Tracker tracker;
|
||||
|
||||
// logger
|
||||
private static final Logger LOG = LoggerFactory.getLogger(SLSCapacityScheduler.class);
|
||||
|
||||
public Tracker getTracker() {
|
||||
return tracker;
|
||||
}
|
||||
@ -218,6 +223,14 @@ public class SLSCapacityScheduler extends CapacityScheduler implements
|
||||
AppAttemptRemovedSchedulerEvent appRemoveEvent =
|
||||
(AppAttemptRemovedSchedulerEvent) schedulerEvent;
|
||||
appQueueMap.remove(appRemoveEvent.getApplicationAttemptID());
|
||||
if (SLSRunner.getRemainingApps() == 0) {
|
||||
try {
|
||||
getSchedulerMetrics().tearDown();
|
||||
SLSRunner.exitSLSRunner();
|
||||
} catch (Exception e) {
|
||||
LOG.error("Scheduler Metrics failed to tear down.", e);
|
||||
}
|
||||
}
|
||||
} else if (schedulerEvent.getType() ==
|
||||
SchedulerEventType.APP_ATTEMPT_ADDED
|
||||
&& schedulerEvent instanceof AppAttemptAddedSchedulerEvent) {
|
||||
|
@ -44,6 +44,8 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.FairSchedule
|
||||
import org.apache.hadoop.yarn.sls.SLSRunner;
|
||||
import org.apache.hadoop.yarn.sls.conf.SLSConfiguration;
|
||||
import org.apache.hadoop.yarn.util.resource.Resources;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.HashSet;
|
||||
@ -63,6 +65,9 @@ public class SLSFairScheduler extends FairScheduler
|
||||
private Map<ContainerId, Resource> preemptionContainerMap =
|
||||
new ConcurrentHashMap<>();
|
||||
|
||||
// logger
|
||||
private static final Logger LOG = LoggerFactory.getLogger(SLSCapacityScheduler.class);
|
||||
|
||||
public SchedulerMetrics getSchedulerMetrics() {
|
||||
return schedulerMetrics;
|
||||
}
|
||||
@ -182,6 +187,14 @@ public class SLSFairScheduler extends FairScheduler
|
||||
if (schedulerEvent.getType() == SchedulerEventType.APP_ATTEMPT_REMOVED
|
||||
&& schedulerEvent instanceof AppAttemptRemovedSchedulerEvent) {
|
||||
SLSRunner.decreaseRemainingApps();
|
||||
if (SLSRunner.getRemainingApps() == 0) {
|
||||
try {
|
||||
getSchedulerMetrics().tearDown();
|
||||
SLSRunner.exitSLSRunner();
|
||||
} catch (Exception e) {
|
||||
LOG.error("Scheduler Metrics failed to tear down.", e);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -539,9 +539,13 @@ public abstract class SchedulerMetrics {
|
||||
}
|
||||
|
||||
void tearDown() throws Exception {
|
||||
setRunning(false);
|
||||
LOG.info("Scheduler Metrics tears down");
|
||||
if (metricsLogBW != null) {
|
||||
metricsLogBW.write("]");
|
||||
metricsLogBW.close();
|
||||
//metricsLogBW is nullified to prevent the usage after closing
|
||||
metricsLogBW = null;
|
||||
}
|
||||
|
||||
if (web != null) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user