All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.alibaba.nacos.config.server.monitor.ResponseMonitor Maven / Gradle / Ivy

There is a newer version: 3.0.0-ALPHA.2
Show newest version
/*
 * Copyright 1999-2018 Alibaba Group Holding Ltd.
 *
 * 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.
 */

package com.alibaba.nacos.config.server.monitor;

import java.text.DecimalFormat;
import java.util.concurrent.atomic.AtomicLong;

/**
 * Response Monitory.
 *
 * @author Nacos
 */
public class ResponseMonitor {
    
    private static AtomicLong[] getConfigCountDetail = new AtomicLong[8];
    
    private static AtomicLong getConfigCount = new AtomicLong();
    
    private static final int MS_50 = 50;
    
    private static final int MS_100 = 100;
    
    private static final int MS_200 = 200;
    
    private static final int MS_500 = 500;
    
    private static final int MS_1000 = 1000;
    
    private static final int MS_2000 = 2000;
    
    private static final int MS_3000 = 3000;
    
    static {
        refresh();
    }
    
    /**
     * Refresh for getting configCountDetail.
     */
    public static void refresh() {
        for (int i = 0; i < getConfigCountDetail.length; i++) {
            getConfigCountDetail[i] = new AtomicLong();
        }
    }
    
    /**
     * AddConfigTime.
     *
     * @param time config time which is added.
     */
    public static void addConfigTime(long time) {
        getConfigCount.incrementAndGet();
        if (time < MS_50) {
            getConfigCountDetail[0].incrementAndGet();
        } else if (time < MS_100) {
            getConfigCountDetail[1].incrementAndGet();
        } else if (time < MS_200) {
            getConfigCountDetail[2].incrementAndGet();
        } else if (time < MS_500) {
            getConfigCountDetail[3].incrementAndGet();
        } else if (time < MS_1000) {
            getConfigCountDetail[4].incrementAndGet();
        } else if (time < MS_2000) {
            getConfigCountDetail[5].incrementAndGet();
        } else if (time < MS_3000) {
            getConfigCountDetail[6].incrementAndGet();
        } else {
            getConfigCountDetail[7].incrementAndGet();
        }
    }
    
    public static String getStringForPrint() {
        DecimalFormat df = new DecimalFormat("##.0");
        StringBuilder s = new StringBuilder("getConfig monitor:\r\n");
        s.append("0-50ms:" + df.format(getConfigCountDetail[0].getAndSet(0) * 100 / getConfigCount.get()))
                .append("%\r\n");
        s.append("100-200ms:" + df.format(getConfigCountDetail[2].getAndSet(0) * 100 / getConfigCount.get()))
                .append("%\r\n");
        s.append("200-500ms:" + df.format(getConfigCountDetail[3].getAndSet(0) * 100 / getConfigCount.get()))
                .append("%\r\n");
        s.append("500-1000ms:" + df.format(getConfigCountDetail[4].getAndSet(0) * 100 / getConfigCount.get()))
                .append("%\r\n");
        s.append("1000-2000ms:" + df.format(getConfigCountDetail[5].getAndSet(0) * 100 / getConfigCount.get()))
                .append("%\r\n");
        s.append("2000-3000ms:" + df.format(getConfigCountDetail[6].getAndSet(0) * 100 / getConfigCount.get()))
                .append("%\r\n");
        s.append("3000以上ms:" + df.format(getConfigCountDetail[7].getAndSet(0) * 100 / getConfigCount.getAndSet(0)))
                .append("%\r\n");
        return s.toString();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy