Htop

為什麼 htop 在打開時會射到 100% CPU?

  • March 29, 2018

每當我打開htop時,它會顯示單核 CPU 使用率突然飆升至 100%。我認為收集統計數據htop不是那麼密集嗎?

為什麼會htop突然出現這個尖峰?

您會看到程序看到其載入資源使用情況的副作用。將執行檔及其庫載入到記憶體中、初始化並將控制權交給程序並不是一項免費操作:它涉及 CPU、記憶體和(如果尚未記憶體)磁碟。

這是top在啟動時立即顯示它的用法:

top - 13:21:29 up 1 day, 23:31,  1 user,  load average: 1.73, 1.78, 1.46
Tasks: 151 total,   3 running,  93 sleeping,   0 stopped,   0 zombie
%Cpu(s): 16.4 us,  5.7 sy,  0.0 ni, 73.1 id,  4.6 wa,  0.0 hi,  0.2 si,  0.0 st
KiB Mem :  3967564 total,   135908 free,  2053480 used,  1778176 buff/cache
KiB Swap:  8388604 total,  8332796 free,    55808 used.  1652564 avail Mem

 PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
 896 qemu      20   0 1961872 508076   6144 S 100.0 12.8 790:22.87 /usr/bin/qemu-system-x86_64 -name guest=Gentoo-amd64,debug-threads=on +
 596 qemu      20   0 2326244 863164   4488 R   6.2 21.8 311:23.29 /usr/bin/qemu-system-x86_64 -name guest=data,debug-threads=on -S -obje+
12655 root      20   0   49732   4164   3432 R   6.2  0.1   0:00.01 top -d 10
   1 root      20   0   49568   5492   3700 S   0.0  0.1   0:02.52 /lib/systemd/systemd --switched-root --system --deserialize 32

10 秒後(對於較小的時間段也是如此,但我希望能夠在啟動時復製文本):

 896 qemu      20   0 1961872 508076   6144 R 103.5 12.8 790:33.23 /usr/bin/qemu-system-x86_64 -name guest=Gentoo-amd64,debug-threads=on +
 596 qemu      20   0 2326244 863164   4488 R   8.7 21.8 311:24.16 /usr/bin/qemu-system-x86_64 -name guest=data,debug-threads=on -S -obje+
10200 root      20   0 1354396 131740  29824 S   3.1  3.3  13:05.97 python2.7 /usr/share/virt-manager/virt-manager
10150 root      20   0   66548   6004   4880 S   2.6  0.2   8:22.49 sshd: root@pts/0
 850 qemu      20   0 1726656 300432   5496 S   0.8  7.6  19:30.70 /usr/bin/qemu-system-x86_64 -name guest=distcc-i686,debug-threads=on -+
 328 avahi     20   0   53744   3608   2936 S   0.2  0.1   0:10.93 avahi-daemon: running [server-calgary.local]
 460 root      20   0       0      0      0 S   0.1  0.0   0:04.87 [nfsd]
 475 root      20   0 1282444  13820   8268 S   0.1  0.3   1:13.16 /usr/sbin/libvirtd --listen
9143 root      20   0       0      0      0 I   0.1  0.0   0:36.05 [kworker/1:1]
10146 root      20   0       0      0      0 I   0.1  0.0   0:25.93 [kworker/0:2]
12641 root      20   0       0      0      0 I   0.1  0.0   0:00.02 [kworker/u4:0]
12655 root      20   0   49732   4176   3432 R   0.1  0.1   0:00.02 top -d 10
   1 root      20   0   49568   5492   3700 S   0.0  0.1   0:02.52 /lib/systemd/systemd --switched-root --system --deserialize 32

top真的使用 6.2% 的 CPU 來完成它的工作嗎?不:這是所有程序在啟動時都會進行的載入工作。程序穩定下來後,使用率下降到 0.1%。

不太可能htop使用 100% 的 CPU(那裡可能存在錯誤),但在啟動時它的使用率更高也就不足為奇了。

引用自:https://unix.stackexchange.com/questions/434365