如何定位死迴圈或高CPU利用率linux
阿新 • • 發佈:2018-12-04
轉自:https://www.jianshu.com/p/ee41ac23abe6
最近在完成一個比較大的多執行緒C++離線服務程式後,發現經常會出現卡住的情況,表現為CPU利用率100%左右,一直沒找到程式碼原因,就採用了一個笨到方法,每小時重啟一次服務……
這樣做仍然會有好多資料進不了庫,不是治本的方法,前幾天決定徹底解決這個問題,搜尋發現了gdb的一個強大的功能,gdb attach(如何定位死迴圈或高CPU使用率(linux) - Sonic4x),記錄一下。
找出執行緒
找出CPU利用率高的程序(例如http_xxx)的所有執行緒,進行排序
ps xH -e -o pid,tid,pcpu,cmd --sort=pcpu | grep 'http_xxx'
得到結果:
2233 2245 1.2 http_xxx
2233 2237 80.9 http_xxx
找到執行緒2237的CPU佔用率高。
用gdb找出呼叫棧
gdb,attach pid,info threads顯示所有執行緒
gdb>attach 2233
gdb>info threads
結果如下,可以發現2237的編號為4
4 Thread 0xac1fcb70 (LWP 2237) 0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1
...
* 1 Thread 0xb78496d0 (LWP 2238 0x006e0422 in __kernel_vsyscall ()
使用thread切換執行緒,使用bt顯示執行緒棧
gdb>thread 4
gdb>bt
可以定位到某個函式到某行程式碼了,就找到原因了。