1. 程式人生 > >如何定位死迴圈或高CPU利用率linux

如何定位死迴圈或高CPU利用率linux

轉自: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

可以定位到某個函式到某行程式碼了,就找到原因了。