QueueModuleInstaller.java 2.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 * Copyright 2017, OpenSkywalking Organization All rights reserved.
 *
 * Licensed 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.
 *
 * Project repository: https://github.com/OpenSkywalking/skywalking
 */

19
package org.skywalking.apm.collector.queue;
P
pengys5 已提交
20

P
pengys5 已提交
21 22
import java.util.List;
import org.skywalking.apm.collector.core.CollectorException;
23
import org.skywalking.apm.collector.core.client.ClientException;
P
pengys5 已提交
24
import org.skywalking.apm.collector.core.config.ConfigException;
P
pengys5 已提交
25
import org.skywalking.apm.collector.core.framework.CollectorContextHelper;
P
pengys5 已提交
26
import org.skywalking.apm.collector.core.framework.Context;
P
pengys5 已提交
27
import org.skywalking.apm.collector.core.framework.DefineException;
P
pengys5 已提交
28
import org.skywalking.apm.collector.core.framework.UnexpectedException;
P
pengys5 已提交
29
import org.skywalking.apm.collector.core.module.SingleModuleInstaller;
P
pengys5 已提交
30 31
import org.skywalking.apm.collector.core.server.ServerException;
import org.skywalking.apm.collector.queue.datacarrier.DataCarrierQueueCreator;
P
pengys5 已提交
32 33 34
import org.skywalking.apm.collector.queue.datacarrier.QueueDataCarrierModuleDefine;
import org.skywalking.apm.collector.queue.disruptor.DisruptorQueueCreator;
import org.skywalking.apm.collector.queue.disruptor.QueueDisruptorModuleDefine;
P
pengys5 已提交
35 36 37 38

/**
 * @author pengys5
 */
P
pengys5 已提交
39
public class QueueModuleInstaller extends SingleModuleInstaller {
P
pengys5 已提交
40

P
pengys5 已提交
41 42 43
    @Override public String groupName() {
        return QueueModuleGroupDefine.GROUP_NAME;
    }
P
pengys5 已提交
44

P
pengys5 已提交
45 46 47
    @Override public Context moduleContext() {
        return new QueueModuleContext(groupName());
    }
48

P
pengys5 已提交
49 50 51 52
    @Override public List<String> dependenceModules() {
        return null;
    }

P
pengys5 已提交
53 54
    @Override public void install() throws ClientException, DefineException, ConfigException, ServerException {
        super.install();
P
pengys5 已提交
55 56 57 58 59 60 61 62 63 64
        if (getModuleDefine() instanceof QueueDataCarrierModuleDefine) {
            ((QueueModuleContext)CollectorContextHelper.INSTANCE.getContext(groupName())).setQueueCreator(new DataCarrierQueueCreator());
        } else if (getModuleDefine() instanceof QueueDisruptorModuleDefine) {
            ((QueueModuleContext)CollectorContextHelper.INSTANCE.getContext(groupName())).setQueueCreator(new DisruptorQueueCreator());
        } else {
            throw new UnexpectedException("");
        }
    }

    @Override public void onAfterInstall() throws CollectorException {
P
pengys5 已提交
65 66
    }
}