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

com.taobao.metamorphosis.server.stats.RealTimeStat Maven / Gradle / Ivy

There is a newer version: 1.4.6.2
Show newest version
/*
 * (C) 2007-2012 Alibaba Group Holding Limited.
 * 
 * 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.
 * Authors:
 *   wuhua  , boyan 
 */
package com.taobao.metamorphosis.server.stats;

import java.util.List;

import org.apache.log4j.Logger;

import com.taobao.metamorphosis.utils.MetaStatLog;


/**
 * 
 * 
 * 
 * @author boyan
 * 
 * @since 1.0, 2009-9-16 ????11:56:00
 */

public class RealTimeStat implements RealTimeStatMBean {

    private static final Logger log = Logger.getLogger(RealTimeStat.class);
    private Thread resetTask;


    public RealTimeStat() {
        // TODO ??¶JMX
    }


    public void start() {
        this.resetTask = new Thread(new MetaStatLog.RealTimeStatRestTask());
        this.resetTask.start();
        log.warn("ʵʱͳ??????...");
    }


    public void stop() {
        this.resetTask.interrupt();
        while (this.resetTask.isAlive()) {
            try {
                this.resetTask.join();
            }
            catch (InterruptedException e) {

            }
        }
        log.warn("ʵʱͳ?ƹر?...");
    }


    /*
     * (non-Javadoc)
     * 
     * @see
     * com.taobao.notify.utils.RealTimeNotifyStatMBean#getRealTimeStatKeys()
     */
    @Override
    public List getRealTimeStatItemNames() {
        return MetaStatLog.getRealTimeStatItemNames();
    }


    /*
     * (non-Javadoc)
     * 
     * @see com.taobao.notify.utils.RealTimeNotifyStatMBean#resetStat()
     */
    @Override
    public void resetStat() {
        MetaStatLog.resetRealTimeStat();
    }


    /*
     * (non-Javadoc)
     * 
     * @see com.taobao.notify.utils.RealTimeNotifyStatMBean#getStatDuration()
     */
    @Override
    public long getStatDuration() {
        return (System.currentTimeMillis() - MetaStatLog.lastResetTime) / 1000;
    }


    /*
     * (non-Javadoc)
     * 
     * @see
     * com.taobao.notify.utils.RealTimeNotifyStatMBean#getStatResult(java.lang
     * .String, java.lang.String, java.lang.String)
     */
    @Override
    public String getStatResult(String key1, String key2, String key3) {
        return MetaStatLog.getRealTimeStatResult(key1, key2, key3);
    }


    /*
     * (non-Javadoc)
     * 
     * @see
     * com.taobao.notify.utils.RealTimeNotifyStatMBean#getStatResult(java.lang
     * .String, java.lang.String)
     */
    @Override
    public String getStatResult(String key1, String key2) {
        return MetaStatLog.getRealTimeStatResult(key1, key2, "*");
    }


    /*
     * (non-Javadoc)
     * 
     * @see
     * com.taobao.notify.utils.RealTimeNotifyStatMBean#getStatResult(java.lang
     * .String)
     */
    @Override
    public String getStatResult(String key1) {
        return MetaStatLog.getRealTimeStatResult(key1, "*", "*");
    }


    @Override
    public String getGroupedRealTimeStatResult(String key1) {
        return MetaStatLog.getGroupedRealTimeStatResult(key1);
    }


    public String getGroupedRealTimeStatResult(String key1, String key2) {
        return MetaStatLog.getGroupedRealTimeStatResult(key1, key2);
    }


    @Override
    public long getDuration() {
        return MetaStatLog.getDuration();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy