linux cpu 实际进程,linux – 找出高CPU占用率的apache进程实际上在做什么?
目前我們的服務(wù)器存在一些問題,間歇性地,我們似乎得到了運行和運行的apache進程,占用了100%的CPU.
在運行top時,我們會看到以下內(nèi)容:
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
20788 www-data 20 0 318m 18m 3984 R 100 0.0 40:29.21 /usr/sbin/apache2 -k start
23523 www-data 20 0 319m 20m 4684 R 100 0.0 4:12.36 /usr/sbin/apache2 -k start
我想嘗試找出導(dǎo)致此問題的腳本(或其他任何內(nèi)容),所以我嘗試了:
strace -p 20788
但是根本沒有顯示任何輸出(我已經(jīng)離開它大約10分鐘,它什么都沒顯示).根據(jù)我的理解,這可能意味著它陷入無限循環(huán),并且沒有任何“系統(tǒng)調(diào)用”顯示.
還有什么我可以做的,以顯示正在發(fā)生的事情?
謝謝
編輯 – 忘記提及,這是一個在任何時候都有幾百個用戶的實時服務(wù)器!所以我真的不能自由地嘗試更改配置選項并重啟apache.
編輯2 – 當(dāng)沒有使用–enable-debug配置PHP時,來自gdb的回溯(bt)似乎沒那么有用 – 它只顯示“execute()”,但我需要知道PHP腳本是什么實際上正在運行..還有其他方法嗎?
#0 0x00007f6c143fb0c5 in ?? () from /usr/lib/apache2/modules/libphp5.so
#1 0x00007f6c143b040b in execute () from /usr/lib/apache2/modules/libphp5.so
#2 0x00007f6c1438b970 in zend_execute_scripts () from /usr/lib/apache2/modules/libphp5.so
#3 0x00007f6c14337fe3 in php_execute_script () from /usr/lib/apache2/modules/libphp5.so
#4 0x00007f6c1441ae7d in ?? () from /usr/lib/apache2/modules/libphp5.so
#5 0x00007f6c18912508 in ap_run_handler ()
#6 0x00007f6c1891297e in ap_invoke_handler ()
#7 0x00007f6c18922570 in ap_process_request ()
#8 0x00007f6c1891f398 in ?? ()
#9 0x00007f6c18918fa8 in ap_run_process_connection ()
#10 0x00007f6c189271d0 in ?? ()
#11 0x00007f6c1892793a in ?? ()
#12 0x00007f6c189284e7 in ap_mpm_run ()
#13 0x00007f6c188fd4a4 in main ()
總結(jié)
以上是生活随笔為你收集整理的linux cpu 实际进程,linux – 找出高CPU占用率的apache进程实际上在做什么?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: win7 linux 共享文件夹权限设置
- 下一篇: linux权限切换命令,Linux基础常