IndicatorProcess.java 5.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */

package org.apache.skywalking.oap.server.core.analysis.worker;

import java.util.*;
22
import lombok.Getter;
23
import org.apache.skywalking.oap.server.core.*;
24 25 26 27 28 29 30 31 32 33 34 35 36
import org.apache.skywalking.oap.server.core.analysis.indicator.Indicator;
import org.apache.skywalking.oap.server.core.storage.*;
import org.apache.skywalking.oap.server.core.storage.annotation.StorageEntityAnnotationUtils;
import org.apache.skywalking.oap.server.core.worker.*;
import org.apache.skywalking.oap.server.library.module.ModuleManager;

/**
 * @author peng-yongsheng
 */
public enum IndicatorProcess {
    INSTANCE;

    private Map<Class<? extends Indicator>, IndicatorAggregateWorker> entryWorkers = new HashMap<>();
37
    @Getter private List<IndicatorPersistentWorker> persistentWorkers = new ArrayList<>();
38 39 40 41 42 43 44 45 46

    public void in(Indicator indicator) {
        entryWorkers.get(indicator.getClass()).in(indicator);
    }

    public void create(ModuleManager moduleManager, Class<? extends Indicator> indicatorClass) {
        String modelName = StorageEntityAnnotationUtils.getModelName(indicatorClass);
        Class<? extends StorageBuilder> builderClass = StorageEntityAnnotationUtils.getBuilder(indicatorClass);

47
        StorageDAO storageDAO = moduleManager.find(StorageModule.NAME).provider().getService(StorageDAO.class);
48 49 50 51 52 53 54
        IIndicatorDAO indicatorDAO;
        try {
            indicatorDAO = storageDAO.newIndicatorDao(builderClass.newInstance());
        } catch (InstantiationException | IllegalAccessException e) {
            throw new UnexpectedException("");
        }

55 56 57 58
        IndicatorPersistentWorker minutePersistentWorker = minutePersistentWorker(moduleManager, indicatorDAO, modelName);
        IndicatorPersistentWorker hourPersistentWorker = worker(moduleManager, indicatorDAO, modelName + Const.ID_SPLIT + Downsampling.Hour.getName());
        IndicatorPersistentWorker dayPersistentWorker = worker(moduleManager, indicatorDAO, modelName + Const.ID_SPLIT + Downsampling.Day.getName());
        IndicatorPersistentWorker monthPersistentWorker = worker(moduleManager, indicatorDAO, modelName + Const.ID_SPLIT + Downsampling.Month.getName());
59

60
        IndicatorTransWorker transWorker = new IndicatorTransWorker(moduleManager, modelName, WorkerIdGenerator.INSTANCES.generate(), minutePersistentWorker, hourPersistentWorker, dayPersistentWorker, monthPersistentWorker);
61
        WorkerInstances.INSTANCES.put(transWorker.getWorkerId(), transWorker);
62

63
        IndicatorRemoteWorker remoteWorker = new IndicatorRemoteWorker(WorkerIdGenerator.INSTANCES.generate(), moduleManager, transWorker, modelName);
64 65
        WorkerInstances.INSTANCES.put(remoteWorker.getWorkerId(), remoteWorker);

66
        IndicatorAggregateWorker aggregateWorker = new IndicatorAggregateWorker(moduleManager, WorkerIdGenerator.INSTANCES.generate(), remoteWorker, modelName);
67 68 69 70
        WorkerInstances.INSTANCES.put(aggregateWorker.getWorkerId(), aggregateWorker);

        entryWorkers.put(indicatorClass, aggregateWorker);
    }
71 72 73 74 75 76

    private IndicatorPersistentWorker minutePersistentWorker(ModuleManager moduleManager,
        IIndicatorDAO indicatorDAO, String modelName) {
        AlarmNotifyWorker alarmNotifyWorker = new AlarmNotifyWorker(WorkerIdGenerator.INSTANCES.generate(), moduleManager);
        WorkerInstances.INSTANCES.put(alarmNotifyWorker.getWorkerId(), alarmNotifyWorker);

wu-sheng's avatar
wu-sheng 已提交
77 78 79
        ExportWorker exportWorker = new ExportWorker(WorkerIdGenerator.INSTANCES.generate(), moduleManager);
        WorkerInstances.INSTANCES.put(exportWorker.getWorkerId(), exportWorker);

80
        IndicatorPersistentWorker minutePersistentWorker = new IndicatorPersistentWorker(WorkerIdGenerator.INSTANCES.generate(), modelName,
wu-sheng's avatar
wu-sheng 已提交
81
            1000, moduleManager, indicatorDAO, alarmNotifyWorker, exportWorker);
82 83 84 85 86 87 88 89 90
        WorkerInstances.INSTANCES.put(minutePersistentWorker.getWorkerId(), minutePersistentWorker);
        persistentWorkers.add(minutePersistentWorker);

        return minutePersistentWorker;
    }

    private IndicatorPersistentWorker worker(ModuleManager moduleManager,
        IIndicatorDAO indicatorDAO, String modelName) {
        IndicatorPersistentWorker persistentWorker = new IndicatorPersistentWorker(WorkerIdGenerator.INSTANCES.generate(), modelName,
wu-sheng's avatar
wu-sheng 已提交
91
            1000, moduleManager, indicatorDAO, null, null);
92 93 94 95 96
        WorkerInstances.INSTANCES.put(persistentWorker.getWorkerId(), persistentWorker);
        persistentWorkers.add(persistentWorker);

        return persistentWorker;
    }
97
}