进程cpu使用率的计算

计算公式

(process jiffies) * 100.0f / ((float)Hertz * (float)et * cpuCoresCount)

亦或html

(process jiffies) * 100.0f / (float)Hertz / (float)et / cpuCoresCount

亦或linux

100 * (process jiffies)/ (float)Hertz / (float)et  / cpuCoresCount

至关于top -p pid 中 %CPU 的值segmentfault

process jiffies的计算

process jiffies是内核提供的该进程在DeltaT时间内消耗的jiffies。具体是/proc/<pid>/stat文件的第14-17 token。14-17token分别是utime, stime, cutime, cstime。cutime/cstime分别是该进程spawn的子进程在用户态和内核态消耗的jiffies。函数

process jiffies = utime + stime + cutime + cstimeui

Jiffies 为Linux核心变数(unsigned long),它被用来记录系统自开机以来,已通过了多少tick。每发生一次timer interrupt,Jiffies变数会被加一。spa

注意stat中的jiffies是一个绝对累计值,因此要取两个时间点,算DeltaT中消耗的jiffies。.net

(process jiffies) = (current process jiffies) - (last process jiffies)线程

Hertz(tick per second)

什么是jiffies呢?其实就是Linux内核定义的一个时间单位,值就是1/Hertz。Linux内核中,进程/线程消耗的时间,单位都是这个 jiffies。code

Hertz就是CLK_TCK,能够根据getconf CLK_TCK获取htm

LINUX系统时钟频率是一个常数HZ来决定的, 一般HZ=100,即100Hz,一个周期即为 1/100s = 10ms = 10^7 ns,那么他的精度度就是10ms(毫秒)。也就是说每10ms一次中断。因此通常来讲Linux的精确度是10毫秒。

et

这里是每次统计的间隔时间,单位为秒

(System.nanoTime() - lastNanoTime) * 1E-9

cpu核数

/usr/bin/nproc

或者

cat /proc/cpuinfo | grep processor | wc -l

doc

相关文章
相关标签/搜索