com.emc.mongoose.base.load.step.service.LoadStepServiceImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mongoose-base Show documentation
Show all versions of mongoose-base Show documentation
Mongoose is a high-load storage performance testing tool
package com.emc.mongoose.base.load.step.service;
import static com.emc.mongoose.base.Constants.KEY_CLASS_NAME;
import static com.emc.mongoose.base.Constants.KEY_STEP_ID;
import static org.apache.logging.log4j.CloseableThreadContext.Instance;
import static org.apache.logging.log4j.CloseableThreadContext.put;
import com.emc.mongoose.base.env.Extension;
import com.emc.mongoose.base.load.step.LoadStepFactory;
import com.emc.mongoose.base.load.step.LoadStep;
import com.emc.mongoose.base.logging.Loggers;
import com.emc.mongoose.base.metrics.MetricsManager;
import com.emc.mongoose.base.metrics.snapshot.AllMetricsSnapshot;
import com.emc.mongoose.base.svc.ServiceBase;
import com.github.akurilov.confuse.Config;
import java.io.IOException;
import java.rmi.RemoteException;
import java.util.List;
import java.util.concurrent.TimeUnit;
public final class LoadStepServiceImpl extends ServiceBase implements LoadStepService {
private final LoadStep localLoadStep;
public LoadStepServiceImpl(
final int port,
final List extensions,
final String stepType,
final Config baseConfig,
final List ctxConfigs,
final MetricsManager metricsManager) {
super(port);
baseConfig.val(
"load-step-idAutoGenerated",
false); // don't override the step-id value on the remote node again
localLoadStep = LoadStepFactory.createLocalLoadStep(
baseConfig, extensions, ctxConfigs, metricsManager, stepType);
final String stepId = baseConfig.stringVal("load-step-id");
try (final Instance logCtx = put(KEY_STEP_ID, stepId).put(KEY_CLASS_NAME, getClass().getSimpleName())) {
Loggers.MSG.info("New step service for type \"{}\"", stepType);
super.doStart();
}
}
@Override
protected final void doStart() {
try (final Instance logCtx = put(KEY_CLASS_NAME, getClass().getSimpleName()).put(KEY_STEP_ID, localLoadStep.id())) {
localLoadStep.start();
Loggers.MSG.info("Step service for \"{}\" is started", localLoadStep.id());
} catch (final RemoteException ignored) {}
}
@Override
protected void doStop() {
try (final Instance logCtx = put(KEY_CLASS_NAME, getClass().getSimpleName()).put(KEY_STEP_ID, localLoadStep.id())) {
localLoadStep.stop();
Loggers.MSG.info("Step service for \"{}\" is stopped", localLoadStep.id());
} catch (final RemoteException ignored) {}
}
@Override
protected final void doClose() throws IOException {
try (final Instance logCtx = put(KEY_CLASS_NAME, getClass().getSimpleName()).put(KEY_STEP_ID, localLoadStep.id())) {
super.doStop();
localLoadStep.close();
Loggers.MSG.info("Step service for \"{}\" is closed", localLoadStep.id());
}
}
@Override
public String name() {
return SVC_NAME_PREFIX + hashCode();
}
@Override
public final String id() throws RemoteException {
return localLoadStep.id();
}
@Override
public final String getTypeName() throws RemoteException {
return localLoadStep.getTypeName();
}
@Override
public final List extends AllMetricsSnapshot> metricsSnapshots() throws RemoteException {
return localLoadStep.metricsSnapshots();
}
@Override
public final boolean await(final long timeout, final TimeUnit timeUnit)
throws IllegalStateException, InterruptedException {
try (final Instance logCtx = put(KEY_CLASS_NAME, getClass().getSimpleName()).put(KEY_STEP_ID, localLoadStep.id())) {
return localLoadStep.await(timeout, timeUnit);
} catch (final RemoteException ignored) {}
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy