com.taobao.metamorphosis.server.stats.RealTimeStat Maven / Gradle / Ivy
/*
* (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