溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Linux系統(tǒng)CPU占用率較高問題怎么進行排查

發(fā)布時間:2021-09-10 14:59:38 來源:億速云 閱讀:248 作者:chen 欄目:系統(tǒng)運維

本篇內(nèi)容介紹了“Linux系統(tǒng)CPU占用率較高問題怎么進行排查”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

很多運維的同學(xué)遇到這種狀況往往會不知所措,對于CPU過載問題通常使用以下兩種方式即可快速定位:

方法一

第一步:使用

top命令,然后按shift+p按照CPU排序

找到占用CPU過高的進程的pid

第二步:使用

top -H -p [進程id]

找到進程中消耗資源***的線程的id

第三步:使用

echo 'obase=16;[線程id]' | bc或者printf "%x\n" [線程id]

將線程id轉(zhuǎn)換為16進制(字母要小寫)

bc是linux的計算器命令

第四步:執(zhí)行

jstack [進程id] |grep -A 10 [線程id的16進制]”

查看線程狀態(tài)信息

方法二

***步:使用

top命令,然后按shift+p按照CPU排序

找到占用CPU過高的進程

第二步:使用

ps -mp pid -o THREAD,tid,time | sort -rn

獲取線程信息,并找到占用CPU高的線程

第三步:使用

echo 'obase=16;[線程id]' | bc或者printf "%x\n" [線程id]

將需要的線程ID轉(zhuǎn)換為16進制格式

第四步:使用

jstack pid |grep tid -A 30 [線程id的16進制]

打印線程的堆棧信息

案例分析

1. 場景描述

生產(chǎn)環(huán)境下JAVA進程高CPU占用故障排查

2. 解決過程

(1) 根據(jù)top命令,發(fā)現(xiàn)PID為2633的Java進程占用CPU高達300%,出現(xiàn)故障。

(2) 找到該進程后,如何定位具體線程或代碼呢,首先顯示線程列表,并按照CPU占用高的線程排序:

[root@localhost ~]# ps -mp 2633 -o THREAD,tid,time | sort -rn

顯示結(jié)果如下:

Linux系統(tǒng)CPU占用率較高問題怎么進行排查

找到了耗時***的線程(TID)3626,占用CPU時間有12分鐘了!

(3) 將需要的線程TID轉(zhuǎn)換為16進制格式

[root@localhost ~]# printf "%x\n" 3626 e18

(4) ***使用jstack命令打印出該進程下面的此線程的堆棧信息:

[root@localhost ~]# jstack 2633 |grep "e18" -A 30

“Linux系統(tǒng)CPU占用率較高問題怎么進行排查”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI