SegmentCostPersistenceWorker.java 2.4 KB
Newer Older
P
pengys5 已提交
1
package org.skywalking.apm.collector.agentstream.worker.segment.cost;
P
pengys5 已提交
2

P
pengys5 已提交
3
import org.skywalking.apm.collector.agentstream.worker.segment.cost.dao.ISegmentCostDAO;
P
pengys5 已提交
4
import org.skywalking.apm.collector.storage.define.segment.SegmentCostDataDefine;
P
pengys5 已提交
5 6 7 8 9 10
import org.skywalking.apm.collector.storage.dao.DAOContainer;
import org.skywalking.apm.collector.stream.worker.AbstractLocalAsyncWorkerProvider;
import org.skywalking.apm.collector.stream.worker.ClusterWorkerContext;
import org.skywalking.apm.collector.stream.worker.ProviderNotFoundException;
import org.skywalking.apm.collector.stream.worker.Role;
import org.skywalking.apm.collector.stream.worker.impl.PersistenceWorker;
11
import org.skywalking.apm.collector.stream.worker.impl.dao.IPersistenceDAO;
P
pengys5 已提交
12
import org.skywalking.apm.collector.storage.define.DataDefine;
P
pengys5 已提交
13 14 15 16 17 18
import org.skywalking.apm.collector.stream.worker.selector.RollingSelector;
import org.skywalking.apm.collector.stream.worker.selector.WorkerSelector;

/**
 * @author pengys5
 */
P
pengys5 已提交
19
public class SegmentCostPersistenceWorker extends PersistenceWorker {
P
pengys5 已提交
20

P
pengys5 已提交
21
    public SegmentCostPersistenceWorker(Role role, ClusterWorkerContext clusterContext) {
P
pengys5 已提交
22 23 24 25 26 27 28
        super(role, clusterContext);
    }

    @Override public void preStart() throws ProviderNotFoundException {
        super.preStart();
    }

29 30 31 32 33 34
    @Override protected boolean needMergeDBData() {
        return false;
    }

    @Override protected IPersistenceDAO persistenceDAO() {
        return (IPersistenceDAO)DAOContainer.INSTANCE.get(ISegmentCostDAO.class.getName());
P
pengys5 已提交
35 36
    }

P
pengys5 已提交
37
    public static class Factory extends AbstractLocalAsyncWorkerProvider<SegmentCostPersistenceWorker> {
P
pengys5 已提交
38 39 40 41 42 43
        @Override
        public Role role() {
            return WorkerRole.INSTANCE;
        }

        @Override
P
pengys5 已提交
44 45
        public SegmentCostPersistenceWorker workerInstance(ClusterWorkerContext clusterContext) {
            return new SegmentCostPersistenceWorker(role(), clusterContext);
P
pengys5 已提交
46 47 48 49 50 51 52 53 54 55 56 57 58
        }

        @Override
        public int queueSize() {
            return 1024;
        }
    }

    public enum WorkerRole implements Role {
        INSTANCE;

        @Override
        public String roleName() {
P
pengys5 已提交
59
            return SegmentCostPersistenceWorker.class.getSimpleName();
P
pengys5 已提交
60 61 62 63 64 65 66 67
        }

        @Override
        public WorkerSelector workerSelector() {
            return new RollingSelector();
        }

        @Override public DataDefine dataDefine() {
P
pengys5 已提交
68
            return new SegmentCostDataDefine();
P
pengys5 已提交
69 70 71
        }
    }
}