package org.skywalking.apm.collector.worker.noderef.persistence;
import org.skywalking.apm.collector.actor.AbstractLocalSyncWorkerProvider;
import org.skywalking.apm.collector.actor.ClusterWorkerContext;
import org.skywalking.apm.collector.actor.LocalWorkerContext;
import org.skywalking.apm.collector.actor.selector.HashCodeSelector;
import org.skywalking.apm.collector.actor.selector.WorkerSelector;
import org.skywalking.apm.collector.worker.MetricPersistenceMember;
import org.skywalking.apm.collector.worker.noderef.NodeRefResSumIndex;
import org.skywalking.apm.collector.worker.storage.PersistenceWorkerListener;
/**
* @author pengys5
*/
public class NodeRefResSumHourSave extends MetricPersistenceMember {
NodeRefResSumHourSave(org.skywalking.apm.collector.actor.Role role, ClusterWorkerContext clusterContext,
LocalWorkerContext selfContext) {
super(role, clusterContext, selfContext);
}
@Override
public String esIndex() {
return NodeRefResSumIndex.INDEX;
}
@Override
public String esType() {
return NodeRefResSumIndex.TYPE_HOUR;
}
public static class Factory extends AbstractLocalSyncWorkerProvider<NodeRefResSumHourSave> {
@Override
public Role role() {
return Role.INSTANCE;
}
@Override
public NodeRefResSumHourSave workerInstance(ClusterWorkerContext clusterContext) {
NodeRefResSumHourSave worker = new NodeRefResSumHourSave(role(), clusterContext, new LocalWorkerContext());
PersistenceWorkerListener.INSTANCE.register(worker);
return worker;
}
}
public enum Role implements org.skywalking.apm.collector.actor.Role {
INSTANCE;
@Override
public String roleName() {
return NodeRefResSumHourSave.class.getSimpleName();
}
@Override
public WorkerSelector workerSelector() {
return new HashCodeSelector();
}
}
}