實戰(zhàn)-用top和jstack命令查找線上CPU消耗過高的線程

前言

在互聯(lián)網(wǎng)行業(yè)中,高并發(fā)的業(yè)務(wù)為常態(tài)区端,作為一名Java高級工程師,線上問題的排查手段和技巧必須熟練卦洽,比如某電商團隊的某個應(yīng)用突然CPU超高江锨,導(dǎo)致報警短信和郵件滿天飛吃警,如果讓你來定位一個問題,并快速消除預(yù)警泳桦,你該怎么辦汤徽?其中一點就是如何定位CPU消耗過高的線程,以及如何找到線程正在干的事情灸撰。幫助我們快速的定位問題和分析問題谒府。

本文為日常工作中實戰(zhàn)性較強的一個問題分析和定位技能。閱讀完本文浮毯,你將擁有更高層次的問題分析和處理能力完疫。

如何定位CPU高的線程

大體過程如下:

1、用top -H -p <pid>命令找到CPU高的線程ID债蓝。
2壳鹤、用jstack <vmid>命令打印jvm線程堆棧信息。
3饰迹、將第1步拿到的線程ID轉(zhuǎn)換為16進制芳誓。(可以用命令 printf '%x\n' ID來輸出16進制)
4余舶、用轉(zhuǎn)換后的線程ID在線程堆棧信息中查找匹配的nid線程。
5锹淌、到此已經(jīng)找到線程匿值,以及線程棧的詳細信息÷赴冢可以根據(jù)這些信息來判斷應(yīng)用當(dāng)前正在干什么壞事了挟憔。

定位Java線程CPU消耗高的線程(top -H命令)

命令:pid為jvm進程號

top -H -p <pid>

作用:列出指定進程下線程的信息,會按CPU的使用占比從大到小排列烟号。

top -H -p <pid>得到的線程堆棸硖罚快照信息

上圖中列分別代表的意思為:進程中的線程ID、用戶名汪拥、線程優(yōu)先級

列名 含義
PID 進程ID
USER linux用戶名
PR 線程優(yōu)先級
NI nice值达传。負值表示高優(yōu)先級,正值表示低優(yōu)先級
VIRT 進程使用的虛擬內(nèi)存總量迫筑,單位kb趟大。VIRT=SWAP+RES
RES 進程使用的、未被換出的物理內(nèi)存大小铣焊,單位kb逊朽。RES=CODE+DATA
SHR 共享內(nèi)存大小,單位kb
S 進程狀態(tài)曲伊。
%CPU 上次更新到現(xiàn)在的CPU時間占用百分比
%MEM 進程使用的物理內(nèi)存百分比
TIME+ 進程使用的CPU時間總計叽讳,格式:時:分:秒
COMMAND 命令名/命令行

上面的幾個參數(shù)中,最關(guān)心的是PID坟募、USER岛蚤、%CPU信息。從上圖中可以看到CPU占比最高的排在第1位懈糯,線程ID位14153(十六進制為:3749)涤妒,這個線程就是我們想要的線程。

jstack命令

命令:pid為jvm進程號
作用:獲取JVM線程堆椬快照

jstack <pid>
jstack得到的線程堆棧信息

在線程堆棧中提供如下的幾個信息:

1她紫、jvm內(nèi)部的線程ID(tid), 操作系統(tǒng)上對應(yīng)的線程ID(nid)
2、線程鎖的狀態(tài)屿储,以及線程棧的軌跡信息贿讹。

如上圖,線程JStack-Test對應(yīng)的操作系統(tǒng)上的線程ID為0x3749

nid=0x3749

拿到這個ID够掠,是不是有點高興民褂?有沒有發(fā)現(xiàn)這個ID就是上一步中用top命令得到的ID?

有了線程堆棧信息,就能夠根據(jù)線程棧軌跡赊堪、線程的狀態(tài)來判斷是否有死鎖面殖,線程執(zhí)行的代碼是什么代碼。從而在這些信息的基礎(chǔ)上進一步幫助我們分析系統(tǒng)的瓶頸哭廉、線程死鎖畜普、CPU資源消耗等情況。

對于線程堆棧的分析群叶,將另起一篇文章來講解。
敬請期待6鄣础=至ⅰ!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末埠通,一起剝皮案震驚了整個濱河市赎离,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌端辱,老刑警劉巖梁剔,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異舞蔽,居然都是意外死亡荣病,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進店門渗柿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來个盆,“玉大人,你說我怎么就攤上這事朵栖〖樟粒” “怎么了?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵陨溅,是天一觀的道長终惑。 經(jīng)常有香客問我,道長门扇,這世上最難降的妖魔是什么雹有? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮臼寄,結(jié)果婚禮上件舵,老公的妹妹穿的比我還像新娘。我一直安慰自己脯厨,他們只是感情好铅祸,可當(dāng)我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般临梗。 火紅的嫁衣襯著肌膚如雪涡扼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天盟庞,我揣著相機與錄音吃沪,去河邊找鬼。 笑死什猖,一個胖子當(dāng)著我的面吹牛票彪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播不狮,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼降铸,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了摇零?” 一聲冷哼從身側(cè)響起推掸,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎驻仅,沒想到半個月后谅畅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡噪服,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年毡泻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片粘优。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡牙捉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出敬飒,到底是詐尸還是另有隱情邪铲,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布无拗,位于F島的核電站带到,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏英染。R本人自食惡果不足惜揽惹,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望四康。 院中可真熱鬧搪搏,春花似錦、人聲如沸闪金。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至囱嫩,卻和暖如春恃疯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背墨闲。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工今妄, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鸳碧。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓盾鳞,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瞻离。 傳聞我的和親對象是個殘疾皇子腾仅,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,492評論 2 348

推薦閱讀更多精彩內(nèi)容