arthas/tutorials/katacoda/command-thread-cn/CPU-ratios-calculate.md
gongdewei 503e0de6b4
improve dashboard/thread cpu time sample (#1501)
* dashboard command support native thread, delta time
* thread command support --all option
2020-09-22 22:18:51 +08:00

1.2 KiB
Raw Blame History

cpu使用率是如何统计出来的

这里的cpu使用率与linux 命令top -H -p <pid> 的线程%CPU类似一段采样间隔时间内当前JVM里各个线程的增量cpu时间与采样间隔时间的比例。

工作原理说明:

  • 首先第一次采样获取所有线程的CPU时间(调用的是java.lang.management.ThreadMXBean#getThreadCpuTime()sun.management.HotspotThreadMBean.getInternalThreadCpuTimes()接口)
  • 然后睡眠等待一个间隔时间默认为200ms可以通过-i指定间隔时间)
  • 再次第二次采样获取所有线程的CPU时间对比两次采样数据计算出每个线程的增量CPU时间
  • 线程CPU使用率 = 线程增量CPU时间 / 采样间隔时间 * 100%

注意: 这个统计也会产生一定的开销JDK这个接口本身开销比较大因此会看到as的线程占用一定的百分比为了降低统计自身的开销带来的影响可以把采样间隔拉长一些比如5000毫秒。

另外一种查看Java进程的线程cpu使用率方法可以使用show-busy-java-threads这个脚本