您好,登錄后才能下訂單哦!
本篇內容介紹了“Linux系統CPU占用率較高問題怎么進行排查”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
很多運維的同學遇到這種狀況往往會不知所措,對于CPU過載問題通常使用以下兩種方式即可快速定位:
方法一
第一步:使用
top命令,然后按shift+p按照CPU排序
找到占用CPU過高的進程的pid
第二步:使用
top -H -p [進程id]
找到進程中消耗資源***的線程的id
第三步:使用
echo 'obase=16;[線程id]' | bc或者printf "%x\n" [線程id]
將線程id轉換為16進制(字母要小寫)
bc是linux的計算器命令
第四步:執行
jstack [進程id] |grep -A 10 [線程id的16進制]”
查看線程狀態信息
方法二
***步:使用
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轉換為16進制格式
第四步:使用
jstack pid |grep tid -A 30 [線程id的16進制]
打印線程的堆棧信息
案例分析
1. 場景描述
生產環境下JAVA進程高CPU占用故障排查
2. 解決過程
(1) 根據top命令,發現PID為2633的Java進程占用CPU高達300%,出現故障。
(2) 找到該進程后,如何定位具體線程或代碼呢,首先顯示線程列表,并按照CPU占用高的線程排序:
[root@localhost ~]# ps -mp 2633 -o THREAD,tid,time | sort -rn
顯示結果如下:
找到了耗時***的線程(TID)3626,占用CPU時間有12分鐘了!
(3) 將需要的線程TID轉換為16進制格式
[root@localhost ~]# printf "%x\n" 3626 e18
(4) ***使用jstack命令打印出該進程下面的此線程的堆棧信息:
[root@localhost ~]# jstack 2633 |grep "e18" -A 30
“Linux系統CPU占用率較高問題怎么進行排查”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。