英文原文: https://www.kernel.org/doc/html/latest/admin-guide/cgroup-v1/cpuacct.html CPU Accounting Controller CPU統計控制器(CPU Accounting Controller)用來分組使用cgr ...
英文原文:
https://www.kernel.org/doc/html/latest/admin-guide/cgroup-v1/cpuacct.html
CPU Accounting Controller
CPU統計控制器(CPU Accounting Controller)用來分組使用cgroup的任務,以及統計這些任務分組的CPU用量。
CPU統計控制器支持多層次架構的分組。一個統計分組累加所有子分組和分組中的任務的CPU用量。
統計分組可以通過掛載cgroup文件系統來創建:
# mount -t cgroup -o cpuacct none /sys/fs/cgroup
完成上述操作,父級統計分組就會在/sys/fs/cgroup變為可見。在啟動的時候,這個分組包含了系統中所有的任務。/sys/fs/cgroup/tasks列舉了該cgroup中的所有任務。/sys/fs/cgroup/cpuacct.usage給出了這個這個分組中所有任務獲取的CPU時間(以納秒為單位)。
在父分組/sys/fs/cgroup下可以創建新的統計分組:
# cd /sys/fs/cgroup
# mkdir g1
# echo $$ > g1/tasks
上述操作創建了新的g1分組,把當前shell進程移動進去。這個bash和她的子孫消耗的CPU時間可以從g1/cpuacct.usage獲取。/sys/fs/cgroup/cpuacct.usage同樣也是累加的。
cpuacct.stat文件列舉了幾個統計數字,劃分成用戶和系統的CPU時間。這些統計數組支持:
用戶:用戶模式里的cgroup任務花費的CPU時間。
系統:內核模式里的cgroup任務花費的CPU時間。
用戶和系統的CPU時間單位都是USER_HZ。
cpuacct控制器使用percpu_counter介面來收集用戶和系統時間。這會有兩個副作用:
- 理論上可能會看到用戶時間和系統時間的錯誤數值。這是因為32位系統上的percpu_counter_read()函數寫併發是不安全的。
- 用戶時間和系統時間可能會稍微有點過時,這是因為percpu_counter的批量處理性質決定的。