如何简单地测算系统吞吐量

在流计算、数据传输之类的系统中,有时候需要统计、压测下一下系统的吞吐能力,这里写了一段简单实现记录一下,方便以后使用,构造参数有两个,一个是name,用于区分,一个是采样周期。
发送或者接收代码中调用update方法即可


public class ThroughputProbe extends TimerTask {
     private static Logger log = Logger.getLogger(ThroughputProbe.class);
     private long count = 0;
     private int sampleCount = 0;
     private long samplingRateInSeconds;
     private String name;
     private double maxThroughput = 0.0;
     private double minThroughput = Double.MAX_VALUE;
     private double accumulatedThroughput = 0.0;
     DecimalFormat formatter = new DecimalFormat("#.000");
     Timer timer;
     private long totalEventCount = 0;

public ThroughputProbe(String name, int samplingRateInSeconds){
    this.name = name;
    this.samplingRateInSeconds = samplingRateInSeconds;
}

public void startSampling(){
    count = 0l;
    timer = new Timer();
    timer.schedule(this, samplingRateInSeconds * 1000, samplingRateInSeconds * 1000);
}


public void update(){
    count++;
    totalEventCount++;
}


@Override
public void run() {
    if (log.isDebugEnabled()){
        if (totalEventCount > 0){
            double throughput = count / samplingRateInSeconds;

            if (maxThroughput < throughput){
                maxThroughput = throughput;
            }
            if (minThroughput > throughput && throughput != 0.0){
                minThroughput = throughput;
            }

            accumulatedThroughput += throughput;
            sampleCount++;

            log.debug("[ThroughputProbe:" + name + "] " + count + " events in " + samplingRateInSeconds
                    + " seconds. Throughput=" + formatter.format(throughput)
                    + " events/s.(Avg=" + formatter.format(accumulatedThroughput / sampleCount)
                    + " ,Max=" + formatter.format(maxThroughput)
                    + " ,Min=" + ((minThroughput == Double.MAX_VALUE) ? "0.0" : formatter.format(minThroughput))
                    + " ) TotalEvents=" + totalEventCount);

            count = 0l;
        }
    }
}
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
系统吞吐量和延迟是两个常用的性能指标,它们在不同场景下有不同的应用和衡量方式。下面以几个例子来说明系统吞吐量和延迟的概念: 1. 网络路由器:在网络路由器的场景中,系统吞吐量指的是路由器每秒钟能够处理的数据包数量。例如,一台路由器的吞吐量为10 Gbps,表示它每秒可以处理10亿比特的数据包。 而延迟则指的是从数据包进入路由器到离开路由器所经过的时间。通常以毫秒(ms)为单位衡量。例如,一个路由器的延迟为5 ms,表示数据包在经过该路由器时会增加5毫秒的延迟。 2. 数据库系统:在数据库系统中,系统吞吐量表示数据库每秒钟能够执行的事务数量。例如,一个数据库系统吞吐量为1000 tps(transactions per second),表示它每秒可以处理1000个事务。 而延迟则指的是执行一个事务所需的时间。通常以毫秒(ms)为单位衡量。例如,一个数据库系统的延迟为10 ms,表示执行一个事务需要花费10毫秒的时间。 3. 分布式计算:在分布式计算中,系统吞吐量指的是集群每秒钟能够处理的作业数量或数据量。例如,一个分布式计算集群的吞吐量为1000作业/秒,表示它每秒可以处理1000个作业。 而延迟则指的是作业执行完成所需的时间。通常以秒为单位衡量。例如,一个作业的延迟为10秒,表示该作业执行完成需要花费10秒的时间。 综上所述,系统吞吐量和延迟是两个常用的性能指标,吞吐量衡量系统单位时间内处理的数量或数据量,而延迟衡量系统完成一个任务所需的时间。在不同的领域和场景中,对吞吐量和延迟的要求会有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值