日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

本文出自頭條號老王談運維,轉載請說明出處。

作為 linux 運維工程師,在日常工作中我們會遇到 Linux服務器上出現CPU負載達到100%居高不下的情況,如果CPU 持續跑高,則會影響業務系統的正常運行,帶來企業損失。

Linux 系統 CPU 占用率較高問題排查思路

 

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

方法一

第一步:使用

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

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

第二步:使用

top -H -p [進程id]

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

第三步:使用

echo 'obase=16;[線程id]' | bc或者printf "%xn" [線程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 "%xn" [線程id]

將需要的線程ID轉換為16進制格式

第四步:使用

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

打印線程的堆棧信息

案例分析

場景描述

生產環境下JAVA進程高CPU占用故障排查

解決過程

1、根據top命令,發現PID為2633的Java進程占用CPU高達300%,出現故障。

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

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

顯示結果如下:

Linux 系統 CPU 占用率較高問題排查思路

 

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

3、將需要的線程TID轉換為16進制格式

[root@localhost%20~]#%20printf%20"%xn"%203626
e18

4、最后使用jstack命令打印出該進程下面的此線程的堆棧信息:

[root@localhost%20~]#%20jstack%202633%20|grep%20"e18"%20-A%2030

相比故障的解決而言,發現故障也同等的重要!市場上的大多數監控軟件都能實現服務器負載的實時觀測,比如:Zabbix、NagIOS、阿里云監控(針對云服務器)等。但是當中大部分的軟件都需要運維同學主動去設置規則或者檢測才能發現問題,如何被動的也能收到告警呢?

推薦大家一個實用的運維軟件——王教授,對于業務部署在阿里云上的用戶,只需綁定需要監控的只讀AcessKey,即可將云上資源的告警信息及時通知給對應的團隊成員。

 

化主動為被動的方式,一方面減輕了運維工程師的工作,另一方面也減小了運維漏看或者忽略告警的情況發生。

分享到:
標簽:Linux CPU
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定