CoreModuleProvider.java 6.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
/*
 * 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;

21
import java.io.IOException;
22
import org.apache.skywalking.oap.server.core.analysis.indicator.annotation.IndicatorTypeListener;
23
import org.apache.skywalking.oap.server.core.annotation.AnnotationScan;
24
import org.apache.skywalking.oap.server.core.cache.*;
彭勇升 pengys 已提交
25
import org.apache.skywalking.oap.server.core.cluster.*;
彭勇升 pengys 已提交
26
import org.apache.skywalking.oap.server.core.register.annotation.InventoryTypeListener;
27
import org.apache.skywalking.oap.server.core.register.service.*;
彭勇升 pengys 已提交
28
import org.apache.skywalking.oap.server.core.remote.*;
29
import org.apache.skywalking.oap.server.core.remote.annotation.*;
彭勇升 pengys 已提交
30 31
import org.apache.skywalking.oap.server.core.remote.client.RemoteClientManager;
import org.apache.skywalking.oap.server.core.server.*;
32
import org.apache.skywalking.oap.server.core.source.*;
33 34
import org.apache.skywalking.oap.server.core.storage.annotation.StorageAnnotationListener;
import org.apache.skywalking.oap.server.core.storage.model.IModelGetter;
彭勇升 pengys 已提交
35
import org.apache.skywalking.oap.server.library.module.*;
36 37 38
import org.apache.skywalking.oap.server.library.server.ServerException;
import org.apache.skywalking.oap.server.library.server.grpc.GRPCServer;
import org.apache.skywalking.oap.server.library.server.jetty.JettyServer;
彭勇升 pengys 已提交
39
import org.slf4j.*;
40 41 42 43 44 45 46 47 48 49 50

/**
 * @author peng-yongsheng
 */
public class CoreModuleProvider extends ModuleProvider {

    private static final Logger logger = LoggerFactory.getLogger(CoreModuleProvider.class);

    private final CoreModuleConfig moduleConfig;
    private GRPCServer grpcServer;
    private JettyServer jettyServer;
51
    private RemoteClientManager remoteClientManager;
52 53 54 55
    private final AnnotationScan annotationScan;
    private final StorageAnnotationListener storageAnnotationListener;
    private final StreamAnnotationListener streamAnnotationListener;
    private final StreamDataAnnotationContainer streamDataAnnotationContainer;
56 57 58 59

    public CoreModuleProvider() {
        super();
        this.moduleConfig = new CoreModuleConfig();
60 61 62 63
        this.annotationScan = new AnnotationScan();
        this.storageAnnotationListener = new StorageAnnotationListener();
        this.streamAnnotationListener = new StreamAnnotationListener();
        this.streamDataAnnotationContainer = new StreamDataAnnotationContainer();
64 65 66 67 68 69
    }

    @Override public String name() {
        return "default";
    }

彭勇升 pengys 已提交
70
    @Override public Class<? extends ModuleDefine> module() {
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
        return CoreModule.class;
    }

    @Override public ModuleConfig createConfigBeanIfAbsent() {
        return moduleConfig;
    }

    @Override public void prepare() throws ServiceNotProvidedException {
        grpcServer = new GRPCServer(moduleConfig.getGRPCHost(), moduleConfig.getGRPCPort());
        grpcServer.initialize();

        jettyServer = new JettyServer(moduleConfig.getRestHost(), moduleConfig.getRestPort(), moduleConfig.getRestContextPath());
        jettyServer.initialize();

        this.registerServiceImplementation(GRPCHandlerRegister.class, new GRPCHandlerRegisterImpl(grpcServer));
        this.registerServiceImplementation(JettyHandlerRegister.class, new JettyHandlerRegisterImpl(jettyServer));

88
        this.registerServiceImplementation(SourceReceiver.class, new SourceReceiverImpl());
彭勇升 pengys 已提交
89

90
        this.registerServiceImplementation(StreamDataClassGetter.class, streamDataAnnotationContainer);
彭勇升 pengys 已提交
91 92

        this.registerServiceImplementation(RemoteSenderService.class, new RemoteSenderService(getManager()));
93 94
        this.registerServiceImplementation(IModelGetter.class, storageAnnotationListener);

95 96 97 98 99 100
        this.registerServiceImplementation(ServiceInventoryCache.class, new ServiceInventoryCache(getManager()));
        this.registerServiceImplementation(IServiceInventoryRegister.class, new ServiceInventoryRegister(getManager()));

        this.registerServiceImplementation(EndpointInventoryCache.class, new EndpointInventoryCache(getManager()));
        this.registerServiceImplementation(IEndpointInventoryRegister.class, new EndpointInventoryRegister(getManager()));

101 102
        annotationScan.registerListener(storageAnnotationListener);
        annotationScan.registerListener(streamAnnotationListener);
103
        annotationScan.registerListener(new IndicatorTypeListener(getManager()));
彭勇升 pengys 已提交
104
        annotationScan.registerListener(new InventoryTypeListener(getManager()));
105 106 107

        this.remoteClientManager = new RemoteClientManager(getManager());
        this.registerServiceImplementation(RemoteClientManager.class, remoteClientManager);
108 109
    }

彭勇升 pengys 已提交
110 111
    @Override public void start() throws ModuleStartException {
        grpcServer.addHandler(new RemoteServiceHandler(getManager()));
112
        remoteClientManager.start();
113

彭勇升 pengys 已提交
114
        try {
115 116 117
            annotationScan.scan(() -> {
                streamDataAnnotationContainer.generate(streamAnnotationListener.getStreamClasses());
            });
118
        } catch (IOException e) {
彭勇升 pengys 已提交
119 120
            throw new ModuleStartException(e.getMessage(), e);
        }
121 122
    }

wu-sheng's avatar
Fix CI.  
wu-sheng 已提交
123
    @Override public void notifyAfterCompleted() throws ModuleStartException {
124 125 126 127 128 129 130
        try {
            grpcServer.start();
            jettyServer.start();
        } catch (ServerException e) {
            throw new ModuleStartException(e.getMessage(), e);
        }

彭勇升 pengys 已提交
131
        RemoteInstance gRPCServerInstance = new RemoteInstance(moduleConfig.getGRPCHost(), moduleConfig.getGRPCPort(), true);
132
        this.getManager().find(ClusterModule.NAME).getService(ClusterRegister.class).registerRemote(gRPCServerInstance);
133
    }
wu-sheng's avatar
wu-sheng 已提交
134 135 136 137 138

    @Override
    public String[] requiredModules() {
        return new String[0];
    }
139
}