Central-Processing-Unit
尋找核心空間程序
我們如何確定正在消耗 CPU 的**%sy程序。**
在以下情況下,沒有netfilter,流量低於1 mbps。但是系統程序仍然佔用過多的cpu,並且niced程序的cpu使用率也很高。我們如何從系統級別確定消耗CPU的程序。
top - 01:22:18 up 10:09, 3 users, load average: 14.36, 13.68, 11.68 Tasks: 200 total, 3 running, 197 sleeping, 0 stopped, 0 zombie Cpu0 : 3.1%us, 63.5%sy, 33.3%ni, 0.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st Cpu1 : 1.8%us, 34.2%sy, 64.0%ni, 0.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st Mem: 16436984k total, 8449956k used, 7987028k free, 73420k buffers Swap: 8385920k total, 0k used, 8385920k free, 5566404k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 5706 tlmsys 27 4 4490m 1.6g 13m S 51.6 10.2 12:37.67 java 4233 oracle 25 0 3448m 47m 33m R 9.9 0.3 0:03.62 oracle 3166 root 15 0 62616 1216 656 S 0.7 0.0 0:01.47 sshd 5512 tlmsys 15 0 96992 12m 9424 S 0.7 0.1 0:04.03 stlfetch 5520 oracle 15 0 3424m 72m 69m S 0.7 0.5 0:08.42 oracle 6 root 10 -5 0 0 0 S 0.3 0.0 0:01.59 events/0 4476 monitor 15 0 90116 1764 1008 S 0.3 0.0 0:00.61 sshd 5872 tlmsys 25 4 4479m 135m 11m S 0.3 0.8 0:25.72 java 7139 oracle 16 0 12740 1180 824 S 0.3 0.0 0:06.76 top 9268 root 16 0 12740 1180 816 S 0.3 0.0 0:02.80 top 9978 root 15 0 12740 1176 820 R 0.3 0.0 0:00.07 top 1 root 15 0 10348 696 584 S 0.0 0.0 0:00.79 init 2 root RT -5 0 0 0 S 0.0 0.0 0:00.02 migration/0 3 root 34 19 0 0 0 S 0.0 0.0 0:00.03 ksoftirqd/0 4 root RT -5 0 0 0 S 0.0 0.0 0:00.01 migration/1 5 root 34 19 0 0 0 R 0.0 0.0 0:00.00 ksoftirqd/1 7 root 10 -5 0 0 0 S 0.0 0.0 0:00.16 events/1 8 root 10 -5 0 0 0 S 0.0 0.0 0:00.09 khelper 145 root 12 -5 0 0 0 S 0.0 0.0 0:00.03 kthread 150 root 10 -5 0 0 0 S 0.0 0.0 0:00.15 kblockd/0 151 root 10 -5 0 0 0 S 0.0 0.0 0:00.03 kblockd/1 152 root 15 -5 0 0 0 S 0.0 0.0 0:00.00 kacpid 311 root 13 -5 0 0 0 S 0.0 0.0 0:00.00 cqueue/0 312 root 13 -5 0 0 0 S 0.0 0.0 0:00.00 cqueue/1 315 root 13 -5 0 0 0 S 0.0 0.0 0:00.00 khubd 317 root 10 -5 0 0 0 S 0.0 0.0 0:00.00 kseriod 389 root 18 0 0 0 0 S 0.0 0.0 0:00.00 pdflush 390 root 15 0 0 0 0 S 0.0 0.0 0:00.78 pdflush 391 root 13 -5 0 0 0 S 0.0 0.0 0:00.00 kswapd0 392 root 13 -5 0 0 0 S 0.0 0.0 0:00.00 aio/0 393 root 13 -5 0 0 0 S 0.0 0.0 0:00.00 aio/1 599 root 11 -5 0 0 0 S 0.0 0.0 0:00.00 kpsmoused 645 root 10 -5 0 0 0 S 0.0 0.0 0:00.01 mpt_poll_0
很明顯,java 佔用了 51.6 %cpu 和 oracle 9.9,所以即使所有程序 cpu 組合在 100% 以下並且平均負載應該在 2 以下,
但為什麼平均負載為 14。
我們如何查看使用高 CPU 的核心程序 (%sy)。
uname -a Linux 2.6.18-155.el5 (todbase1)
如果是核心錯誤。我們還不能從系統端看到程序嗎?
%sy 表示花費在核心程序(真正的核心執行緒)中的時間,以及核心中不是程序的那些部分。核心程序通常顯示在頂部(
ksoftirqd/0
是一個)。如果您按瞬時 CPU 使用率排序,並且它是對 %sy 有貢獻的核心程序,則會顯示該程序。但是,如果不是核心程序而是核心正在執行,top 不會提供任何資訊。具體來說,核心實際上有一個中斷上下文(實際上有幾個,用於硬體和軟體中斷)和一個程序上下文(用於執行系統呼叫)。如果記憶體服務,後一種類型將由導致它們的程序顯示為 CPU 時間。但是,核心的調度方面,以及與系統呼叫或其他中斷處理無關的核心組件的活動,將沒有詳細的記帳資訊。