這篇文章主要介紹了Linux系統(tǒng)中CPU占用率較高問題排查思路的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創(chuàng)新互聯(lián)公司秉承實(shí)現(xiàn)全網(wǎng)價(jià)值營銷的理念,以專業(yè)定制企業(yè)官網(wǎng),做網(wǎng)站、網(wǎng)站制作,微信小程序,網(wǎng)頁設(shè)計(jì)制作,手機(jī)網(wǎng)站開發(fā),成都全網(wǎng)營銷幫助傳統(tǒng)企業(yè)實(shí)現(xiàn)“互聯(lián)網(wǎng)+”轉(zhuǎn)型升級(jí)專業(yè)定制企業(yè)官網(wǎng),公司注重人才、技術(shù)和管理,匯聚了一批優(yōu)秀的互聯(lián)網(wǎng)技術(shù)人才,對客戶都以感恩的心態(tài)奉獻(xiàn)自己的專業(yè)和所長。
前言
作為 Linux 運(yùn)維工程師,在日常工作中我們會(huì)遇到 Linux服務(wù)器上出現(xiàn)CPU負(fù)載達(dá)到100%居高不下的情況,如果CPU 持續(xù)跑高,則會(huì)影響業(yè)務(wù)系統(tǒng)的正常運(yùn)行,帶來企業(yè)損失。
很多運(yùn)維的同學(xué)遇到這種狀況往往會(huì)不知所措,對于CPU過載問題通常使用以下兩種方式即可快速定位:
方法一
第一步:使用
top命令,然后按shift+p按照CPU排序
找到占用CPU過高的進(jìn)程的pid
第二步:使用
top -H -p [進(jìn)程id]
找到進(jìn)程中消耗資源最高的線程的id
第三步:使用
echo 'obase=16;[線程id]' | bc或者printf "%x\n" [線程id]
將線程id轉(zhuǎn)換為16進(jìn)制(字母要小寫)
bc是linux的計(jì)算器命令
第四步:執(zhí)行
jstack [進(jìn)程id] |grep -A 10 [線程id的16進(jìn)制]”
查看線程狀態(tài)信息
方法二
第一步:使用
top命令,然后按shift+p按照CPU排序
找到占用CPU過高的進(jìn)程
第二步:使用
ps -mp pid -o THREAD,tid,time | sort -rn
獲取線程信息,并找到占用CPU高的線程
第三步:使用
echo 'obase=16;[線程id]' | bc或者printf "%x\n" [線程id]
將需要的線程ID轉(zhuǎn)換為16進(jìn)制格式
第四步:使用
jstack pid |grep tid -A 30 [線程id的16進(jìn)制]
打印線程的堆棧信息
案例分析
場景描述
生產(chǎn)環(huán)境下JAVA進(jìn)程高CPU占用故障排查
解決過程
1、根據(jù)top命令,發(fā)現(xiàn)PID為2633的Java進(jìn)程占用CPU高達(dá)300%,出現(xiàn)故障。
2、找到該進(jìn)程后,如何定位具體線程或代碼呢,首先顯示線程列表,并按照CPU占用高的線程排序:
[root@localhost ~]# ps -mp 2633 -o THREAD,tid,time | sort -rn
顯示結(jié)果如下:
找到了耗時(shí)最高的線程(TID)3626,占用CPU時(shí)間有12分鐘了!
3、將需要的線程TID轉(zhuǎn)換為16進(jìn)制格式
[root@localhost ~]# printf "%x\n" 3626 e18
4、最后使用jstack命令打印出該進(jìn)程下面的此線程的堆棧信息:
[root@localhost ~]# jstack 2633 |grep "e18" -A 30
相比故障的解決而言,發(fā)現(xiàn)故障也同等的重要!市場上的大多數(shù)監(jiān)控軟件都能實(shí)現(xiàn)服務(wù)器負(fù)載的實(shí)時(shí)觀測,比如:Zabbix、Nagios、阿里云監(jiān)控(針對云服務(wù)器)等。但是當(dāng)中大部分的軟件都需要運(yùn)維同學(xué)主動(dòng)去設(shè)置規(guī)則或者檢測才能發(fā)現(xiàn)問題,如何被動(dòng)的也能收到告警呢?
推薦大家一個(gè)實(shí)用的運(yùn)維軟件——王教授,對于業(yè)務(wù)部署在阿里云上的用戶,只需綁定需要監(jiān)控的只讀AcessKey,即可將云上資源的告警信息及時(shí)通知給對應(yīng)的團(tuán)隊(duì)成員。
化主動(dòng)為被動(dòng)的方式,一方面減輕了運(yùn)維工程師的工作,另一方面也減小了運(yùn)維漏看或者忽略告警的情況發(fā)生。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Linux系統(tǒng)中CPU占用率較高問題排查思路的示例分析”這篇文章對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!
新聞名稱:Linux系統(tǒng)中CPU占用率較高問題排查思路的示例分析
網(wǎng)頁網(wǎng)址:http://www.chinadenli.net/article44/jcosee.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、網(wǎng)頁設(shè)計(jì)公司、云服務(wù)器、網(wǎng)站設(shè)計(jì)、品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站維護(hù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)