ServiceNameDiscoveryServiceHandler.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
 */

P
pengys5 已提交
19 20 21
package org.skywalking.apm.collector.agentregister.grpc.handler;

import io.grpc.stub.StreamObserver;
P
pengys5 已提交
22 23
import java.util.List;
import org.skywalking.apm.collector.agentregister.servicename.ServiceNameService;
P
pengys5 已提交
24 25 26
import org.skywalking.apm.collector.server.grpc.GRPCHandler;
import org.skywalking.apm.network.proto.ServiceNameCollection;
import org.skywalking.apm.network.proto.ServiceNameDiscoveryServiceGrpc;
P
pengys5 已提交
27
import org.skywalking.apm.network.proto.ServiceNameElement;
P
pengys5 已提交
28
import org.skywalking.apm.network.proto.ServiceNameMappingCollection;
P
pengys5 已提交
29 30 31
import org.skywalking.apm.network.proto.ServiceNameMappingElement;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
P
pengys5 已提交
32 33 34 35 36 37

/**
 * @author pengys5
 */
public class ServiceNameDiscoveryServiceHandler extends ServiceNameDiscoveryServiceGrpc.ServiceNameDiscoveryServiceImplBase implements GRPCHandler {

P
pengys5 已提交
38 39 40 41
    private final Logger logger = LoggerFactory.getLogger(ServiceNameDiscoveryServiceHandler.class);

    private ServiceNameService serviceNameService = new ServiceNameService();

P
pengys5 已提交
42 43
    @Override public void discovery(ServiceNameCollection request,
        StreamObserver<ServiceNameMappingCollection> responseObserver) {
P
pengys5 已提交
44 45 46 47 48 49 50
        List<ServiceNameElement> serviceNameElementList = request.getElementsList();

        ServiceNameMappingCollection.Builder builder = ServiceNameMappingCollection.newBuilder();
        for (ServiceNameElement serviceNameElement : serviceNameElementList) {
            int applicationId = serviceNameElement.getApplicationId();
            String serviceName = serviceNameElement.getServiceName();
            int serviceId = serviceNameService.getOrCreate(applicationId, serviceName);
51 52 53 54 55 56 57

            if (serviceId != 0) {
                ServiceNameMappingElement.Builder mappingElement = ServiceNameMappingElement.newBuilder();
                mappingElement.setServiceId(serviceId);
                mappingElement.setElement(serviceNameElement);
                builder.addElements(mappingElement);
            }
P
pengys5 已提交
58 59 60 61
        }

        responseObserver.onNext(builder.build());
        responseObserver.onCompleted();
P
pengys5 已提交
62 63
    }
}