JVMMetricsServiceHandler.java 4.9 KB
Newer Older
1
/*
wu-sheng's avatar
wu-sheng 已提交
2 3 4 5 6 7
 * 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
8 9 10 11 12 13 14 15 16 17 18
 *
 *     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.
 *
 */

19
package org.apache.skywalking.apm.collector.agent.grpc.provider.handler;
20 21 22

import io.grpc.stub.StreamObserver;
import java.util.List;
P
peng-yongsheng 已提交
23
import org.apache.skywalking.apm.collector.analysis.jvm.define.AnalysisJVMModule;
24
import org.apache.skywalking.apm.collector.analysis.jvm.define.service.*;
25 26
import org.apache.skywalking.apm.collector.analysis.metric.define.AnalysisMetricModule;
import org.apache.skywalking.apm.collector.analysis.metric.define.service.IInstanceHeartBeatService;
27 28 29
import org.apache.skywalking.apm.collector.core.module.ModuleManager;
import org.apache.skywalking.apm.collector.core.util.TimeBucketUtils;
import org.apache.skywalking.apm.collector.server.grpc.GRPCHandler;
30
import org.apache.skywalking.apm.network.language.agent.*;
31
import org.slf4j.*;
32 33 34 35 36 37

/**
 * @author peng-yongsheng
 */
public class JVMMetricsServiceHandler extends JVMMetricsServiceGrpc.JVMMetricsServiceImplBase implements GRPCHandler {

彭勇升 pengys 已提交
38
    private static final Logger logger = LoggerFactory.getLogger(JVMMetricsServiceHandler.class);
39 40 41 42 43

    private final ICpuMetricService cpuMetricService;
    private final IGCMetricService gcMetricService;
    private final IMemoryMetricService memoryMetricService;
    private final IMemoryPoolMetricService memoryPoolMetricService;
44
    private final IInstanceHeartBeatService instanceHeartBeatService;
45 46

    public JVMMetricsServiceHandler(ModuleManager moduleManager) {
P
peng-yongsheng 已提交
47 48 49 50
        this.cpuMetricService = moduleManager.find(AnalysisJVMModule.NAME).getService(ICpuMetricService.class);
        this.gcMetricService = moduleManager.find(AnalysisJVMModule.NAME).getService(IGCMetricService.class);
        this.memoryMetricService = moduleManager.find(AnalysisJVMModule.NAME).getService(IMemoryMetricService.class);
        this.memoryPoolMetricService = moduleManager.find(AnalysisJVMModule.NAME).getService(IMemoryPoolMetricService.class);
51
        this.instanceHeartBeatService = moduleManager.find(AnalysisMetricModule.NAME).getService(IInstanceHeartBeatService.class);
52 53 54 55
    }

    @Override public void collect(JVMMetrics request, StreamObserver<Downstream> responseObserver) {
        int instanceId = request.getApplicationInstanceId();
56 57 58 59

        if (logger.isDebugEnabled()) {
            logger.debug("receive the jvm metric from application instance, id: {}", instanceId);
        }
60 61

        request.getMetricsList().forEach(metric -> {
62 63 64 65 66
            long minuteTimeBucket = TimeBucketUtils.INSTANCE.getMinuteTimeBucket(metric.getTime());
            sendToCpuMetricService(instanceId, minuteTimeBucket, metric.getCpu());
            sendToMemoryMetricService(instanceId, minuteTimeBucket, metric.getMemoryList());
            sendToMemoryPoolMetricService(instanceId, minuteTimeBucket, metric.getMemoryPoolList());
            sendToGCMetricService(instanceId, minuteTimeBucket, metric.getGcList());
67
            sendToInstanceHeartBeatService(instanceId, metric.getTime());
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
        });

        responseObserver.onNext(Downstream.newBuilder().build());
        responseObserver.onCompleted();
    }

    private void sendToMemoryMetricService(int instanceId, long timeBucket, List<Memory> memories) {
        memories.forEach(memory -> memoryMetricService.send(instanceId, timeBucket, memory.getIsHeap(), memory.getInit(), memory.getMax(), memory.getUsed(), memory.getCommitted()));
    }

    private void sendToMemoryPoolMetricService(int instanceId, long timeBucket,
        List<MemoryPool> memoryPools) {

        memoryPools.forEach(memoryPool -> memoryPoolMetricService.send(instanceId, timeBucket, memoryPool.getType().getNumber(), memoryPool.getInit(), memoryPool.getMax(), memoryPool.getUsed(), memoryPool.getCommited()));
    }

    private void sendToCpuMetricService(int instanceId, long timeBucket, CPU cpu) {
        cpuMetricService.send(instanceId, timeBucket, cpu.getUsagePercent());
    }

    private void sendToGCMetricService(int instanceId, long timeBucket, List<GC> gcs) {
        gcs.forEach(gc -> gcMetricService.send(instanceId, timeBucket, gc.getPhraseValue(), gc.getCount(), gc.getTime()));
    }
91 92 93 94

    private void sendToInstanceHeartBeatService(int instanceId, long heartBeatTime) {
        instanceHeartBeatService.heartBeat(instanceId, heartBeatTime);
    }
95
}