(轉(zhuǎn))如何定位死循環(huán)或高CPU利用率linux

最近在完成一個(gè)比較大的多線程C++離線服務(wù)程序后,發(fā)現(xiàn)經(jīng)常會(huì)出現(xiàn)卡住的情況,表現(xiàn)為CPU利用率100%左右,一直沒找到代碼原因,就采用了一個(gè)笨到方法,每小時(shí)重啟一次服務(wù)……

這樣做仍然會(huì)有好多數(shù)據(jù)進(jìn)不了庫,不是治本的方法,前幾天決定徹底解決這個(gè)問題,搜索發(fā)現(xiàn)了gdb的一個(gè)強(qiáng)大的功能,gdb attach(如何定位死循環(huán)或高CPU使用率(linux) - Sonic4x),記錄一下。

找出線程

找出CPU利用率高的進(jìn)程(例如http_xxx)的所有線程,進(jìn)行排序

ps xH -e -o pid,tid,pcpu,cmd --sort=pcpu | grep 'http_xxx'

得到結(jié)果:

2233 2245 1.2 http_xxx

2233 2237 80.9 http_xxx

找到線程2237的CPU占用率高。

用gdb找出調(diào)用棧

gdb,attach pid,info threads顯示所有線程

gdb>attach 2233

gdb>info threads

結(jié)果如下,可以發(fā)現(xiàn)2237的編號(hào)為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

可以定位到某個(gè)函數(shù)到某行代碼了,就找到原因了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 程序調(diào)試的基本思想是“分析現(xiàn)象->假設(shè)錯(cuò)誤原因->產(chǎn)生新的現(xiàn)象去驗(yàn)證假設(shè)”這樣一個(gè)循環(huán)過程,根據(jù)現(xiàn)象如何假設(shè)錯(cuò)誤原...
    Manfred_Zone閱讀 16,746評(píng)論 0 26
  • 又來到了一個(gè)老生常談的問題,應(yīng)用層軟件開發(fā)的程序員要不要了解和深入學(xué)習(xí)操作系統(tǒng)呢? 今天就這個(gè)問題開始,來談?wù)劜?..
    tangsl閱讀 4,322評(píng)論 0 23
  • GDB TO LLDB COMMAND MAP Below is a table of GDB commands ...
    狂風(fēng)無跡閱讀 1,814評(píng)論 0 2
  • 迪倫噩夢醒后,還一時(shí)沉思在恐懼的夢境中久久不能忘懷,可崔斯坦打斷了她的思緒,一句“我們要走了” 把迪倫重新拉回到現(xiàn)...
    棒老韓_木驢閱讀 480評(píng)論 0 1
  • 我不得不吐槽一下我所在的小區(qū)-這個(gè)既美麗又嘈雜的地方。 我住在一個(gè)二線城市里的一個(gè)小縣城的小鎮(zhèn)上的一個(gè)小區(qū)里。小鎮(zhèn)...
    夏日冰雪閱讀 349評(píng)論 0 0

友情鏈接更多精彩內(nèi)容