java中如何使用JVM指令來實作伺服器故障排查
本篇文章就跟大家介紹java中使用JVM指令來實作伺服器故障排查的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對你們有幫助。
一、top(Linux指令)
執行top指令: (查看行程15477的詳細情況,下文用到)
#系統資訊(前五行):
第1行:Top 任務佇列資訊(系統運作狀態及平均負載),與uptime指令結果相同。
系統平均負載:單核心CPU情況下,0.00 表示沒有任何負荷,1.00表示剛好滿載,超過1側表示超負荷,理想值是0.7;
多核心CPU負載:CPU核數* 理想值0.7 = 理想負載,例如:4核心CPU負載不超過2.8何表示沒有出現高負載。
格式:up xx days, HH:MM
例如:241 days, 20:11, 表示連續運行了241天20小時11分鐘
第1段:系統目前時間,例如:16:07:37
#第2段:系統運作時間,未重新啟動的時間,時間越長系統越穩定。
第3段:目前登入使用者數,例如:1 user,表示目前只有1個使用者登入
第4段:系統負載,即任務佇列的平均長度,3個數值分別統計最近1,5,15分鐘的系統平均負載
第2行: Tasks 進程相關資訊
第1段:進程總數,例如:Tasks: 231 total, 表示總共執行231個進程
第2段:正在執行的進程數,例如:1 running,
#第3段:睡眠的進程數,例如:230 sleeping,
#第4段:停止的行程數,例如:0 stopped,
#第5段:殭屍行程數,例如:0 zombie
第3行:Cpus CPU相關訊息,若是多核心CPU,按數字1可顯示各核CPU訊息,此時1行將轉為Cpu核數行,數字1可以來回切換。
第1段:
us
用戶空間佔用CPU百分比#,例如:Cpu (s): 12.7%us,第2段:
sy
核心空間佔用CPU百分比,例如:8.4%sy,#第3段:
ni
使用者進程空間內改變優先權的程序佔用CPU百分比,例如:0.0%ni,第4段:
id
空閒CPU百分比,例如:77.1%id,第5段:
wa
等待輸入輸出的CPU時間百分比,例如:0.0%wa,第6段:
hi
CPU服務硬體中斷所耗費的時間總額,例如:0.0%hi,#第7段:
si
CPU服務軟中斷所耗費的時間總額,例如:1.8%si,第8段:
st
Steal time 虛擬機器被hypervisor偷去的CPU時間(如果目前處於hypervisor下的vm,實際上hypervisor也是要消耗部分CPU處理時間的)#第4行:Mem 內存相關信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)
第1段:實體記憶體總量,例如:Mem: 12196436k total,
第2段:使用的實體記憶體總量,例如: 12056552k used,
第3段:空閒記憶體總量,例如:Mem: 139884k free,
第4段:用作核心快取的記憶體量,例如:64564k buffers
第5行:Swap 交換分區相關資訊(Swap: 2097144k total, 151016k used, 1946128k free free, 151016k used, 1946128k free 3120236k#)
- #第1段:交換區總量,例如:Swap: 2097144k total,
- 第2段:使用的交換區總量,例如:151016k used,
- 第3段:空閒交換區總量,例如:1946128k free,
- #第4段:緩衝的交換區總量,3120236k cached
進程資訊:
在top指令中按f按可查看顯示的列信息,按對應字母開啟/關閉列,大寫字母表示開啟,小寫字母表示關閉。帶*號的是預設列。A: PID
= (Process Id) 程式Id;
-
################################################################ ######E: ###USER### = (User Name) 進程擁有者的使用者名稱;### H:
PR
= (Priority) 優先權- ##I:
NI
= (Nice value) nice值。負值表示高優先權,正值表示低優先權
O: VIRT
= (Virtual Image (kb)) 行程使用的虛擬記憶體總量,單位k
b。 VIRT=SWAP RESQ: RES
= (Resident size (kb)) 進程使用的、未被換出的實體內存大小
,單位kb。 RES=CODE DATA- T:
SHR
= (Shared Mem size (kb)) 共享記憶體大小,單位kb
- #W:
S
= (Process Status) 行程狀態。 D=不可中斷的睡眠狀態,R=運作,S=睡眠,T=追蹤/停止,Z=殭屍行程
K: % CPU
= (CPU usage) 上次更新到現在的CPU時間佔用百分比
N: %MEM
= (Memory usage (RES)) 進程使用的實體記憶體百分比
- M:
TIME
= (CPU Time, hundredths ) 行程使用的CPU時間總計,單位1/100秒
b:
PPID= (Parent Process Pid) 父行程Id
c:
RUSER= (Real user name)
d:
UID= (User Id) 進程擁有者的使用者id
f:
GROUP= (Group Name) 進程擁有者的群組名稱
g:
TTY= (Controlling Tty) 啟動進程的終端名稱。不是從終端機啟動的程序則顯示為?
j:
P= (Last used cpu (SMP)) 最後使用的CPU,僅在多CPU環境下有意義
p:
SWAP= (Swapped size (kb)) 進程使用的虛擬記憶體中,被換出的大小,單位kb
l:
TIME= (CPU Time) 進程使用的CPU時間總計,單位秒
r:
CODE= (Code size (kb)) 可執行程式碼佔用的物理記憶體大小,單位kb
s:
DATA= ( Data Stack size (kb)) 可執行程式碼以外的部分(資料段堆疊)所佔用的實體記憶體大小,單位kb
u:
nFLT= (Page Fault count) 頁面錯誤次數
# v:
nDRT= (Dirty Pages count) 最後一次寫入到現在,被修改過的頁數
y:
WCHAN= (Sleeping in Function) 若該行程在睡眠,則顯示睡眠中的系統函數名稱
z:
Flags= (Task Flags <sched.h>) 任務標誌,參考sched.h
- #X:
COMMAND
= (Command name/line) 指令名稱/命令列
註:此時PID是執行緒id
./jstack PID(進程id) ./jstack 15477
紅框中即為執行緒15571(16進位=3#cd3) 狀態
#分析jstack日誌:
#
監視器Monitor:
# # Monitor是Java中用來實現執行緒之間的互斥與協作的主要手段,它可以看成是物件或Class的鎖。
每個物件都有,也只有一個 monitor。
#進入區(Entrt Set):表示線程透過synchronized要求取得物件的鎖。如果物件被鎖住,則進入擁有者;否則在進入區等待。一旦物件鎖被其他線程釋放,立即參與競爭。
######擁有者(The Owner):表示某一執行緒成功競爭到物件鎖定。 ######等待區(Wait Set):表示執行緒通過物件的object.wait()方法,釋放物件的鎖定,並在等待區等待被喚醒。
從圖中可以看出,一個Monitor在某個時刻,只能被一個執行緒擁有,該執行緒就是 <span style='font-family: "Microsoft YaHei"'>Active Thread</span>
,而它執行緒都是 <span style='font-family: "Microsoft YaHei"'>Waiting</span> <span style='font-family: "Microsoft YaHei"'>Thread</span>
,分別在兩個佇列 <span style='font-family: "Microsoft YaHei"'>Entry</span> <span style='font-family: "Microsoft YaHei"'>Set</span>
和 <span style='font-family: "Microsoft YaHei"'>Wait</span> <span style='font-family: "Microsoft YaHei"'>Set</span>
裡面等候。
在<span style='font-family: "Microsoft YaHei"'>Entry</span> <span style='font-family: "Microsoft YaHei"'>Set</span>
中等待的執行緒動作是 <span style='font-family: "Microsoft YaHei"'>Waiting for monitor entry</span>。
在 <span style='font-family: "Microsoft YaHei"'>Wait</span> <span style='font-family: "Microsoft YaHei"'>Set</span>
#中等待的執行緒動作是 <span style='font-family: "Microsoft YaHei"'>in Object.wait()</span>
。 當一個執行緒申請進入臨界區時,它就進入了 Entry Set佇列。
(我們稱被synchronized保護起來的程式碼片段為臨界區。當一個執行緒申請進入臨界區時,它就進入了「Entry Set 」佇列)
執行緒狀態:
NEW:未啟動的。不會出現在Dump。
RUNNABLE:在虛擬機器內執行的,運行中狀態。 The Owner區
BLOCKED:受阻塞並等待監視器鎖定。 在Entry Set區等鎖定。
WATING:無限期等待另一個執行緒執行特定操作。 在Wait Set區等待某個condition或monitor發生,一般停留在wait()等語句裡。
TIMED_WATING:有時限的等待另一個執行緒的特定操作。 在Wait Set區和WAITING的差異是wait() 等語句加上了時間限制 wait(timeout)。
TERMINATED:已退出的。
呼叫修飾
表示執行緒在方法呼叫時,額外的重要的操作。修飾上方的方法呼叫。
locked <地址> 目標:使用synchronized申請物件鎖定成功,監視器的擁有者。 The Owner區。
waiting to lock <地址> 目標:使用synchronized申請物件鎖定未成功,在Entry Set區等鎖定。執行緒狀態為Blocked
waiting on <位址> 目標:使用synchronized申請物件鎖定成功後,釋放鎖定,在Wait Set區等鎖定。執行緒狀態為WAITING或TIMED_WATING
parking to wait for <位址> 目標:呼叫了park(),在Wait Set區,等待許可。
(park是基本的執行緒阻塞原語,不透過監視器在物件上阻塞。
park:進入WAITING狀態,對比wait不需要取得鎖定就可以讓執行緒WAITING,透過unpark喚醒)
執行緒動作
執行緒狀態產生的原因。
runnable:The Owner區,狀態RUNNABLE
in Object.wait():呼叫wait(),Wait Set區,狀態為WAITING或TIMED_WAITING,修飾waiting on
waiting for monitor entry:等鎖,Entry Set區,狀態BLOCKED,修飾waiting to lock
waiting on condition##:因為某種條件被park,Wait Set區,狀態為parking to wait for
#sleeping:休眠的線程,呼叫了Thread.sleep()
總結
1、查看線程dump,先看線程狀態/線程動作(比較直覺),可以確定線程目前處於哪個階段。然後看呼叫修飾及鎖情況,基本上就可以確定次執行緒是否有問題;
2、可以短時間(可能有問題的時間段)內多次列印執行緒快照,然後查看可能有問題的某一線程在這幾次的情況,可以有效查找問題。
三、jps
類似Linux指令ps
#參考 Java指令學習系列(一)-Jps
./jps
# ./jps -q
#./jps -m
##參考: Java指令學習系列(三)-Jmap
java指令--jmap指令使用
jmap -heap PID:堆疊使用狀況
##jmap -histo PID:物件情況(jmap -histo:live 這個指令執行,JVM會先觸發gc,然後再統計資訊重點看項目上的類別:[C是字串數組,String用; [B是位元組數組,網路層用到。這兩個比較大一般沒關係[C is a char[]
[S is a short[ ]
[I is a int[]
[B is a byte[]
[B is a byte[]
[[I is a int[]
[[I is a int[] [[I is a int[] []總結:以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。更多相關教學請造訪
Java影片教學###,## #java開發圖文教學###,###bootstrap影片教學###!###以上是java中如何使用JVM指令來實作伺服器故障排查的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

有很多Linux初學者經常問起的問題,“Linux有任務管理器嗎?”,“怎樣在Linux上打開任務管理器呢?”來自Windows的用戶都知道任務管理器非常有用。你可以在Windows中按下Ctrl+Alt+Del開啟工作管理員。這個任務管理器向你展示了所有的正在運行的進程和它們消耗的內存,你可以從任務管理器程式中選擇並殺死一個進程。當你剛使用Linux的時候,你也會尋找一個在Linux相當於任務管理器的一個東西。一個Linux使用專家更喜歡使用命令列的方式來尋找進程和消耗的記憶體等等,但是你不用必須

zabbix對中文的支援不是很好,但為了管理方面有時候我們還是會選擇中文,在zabbix監控的web界面,圖形圖標下面的中文會顯示一個個小方塊,這樣是不正確的,需要下載字體。例如“微軟雅黑”,“微軟雅黑.ttf”命名為“msyh.ttf”,將下載的字體上傳到/zabbix/fonts/字體下修改/zabbix/include/defines.inc.php檔案中的兩處define('ZBX_GRAPH_FONT_NAME','DejaVuSans');define('ZBX_FONT_NAME'

你知道嗎,如何在Linux系統上查看帳戶的建立日期?如果知道,那麼有些什麼辦法。你成功了麼?如果是的話,該怎麼做?基本上Linux系統不會追蹤這些信息,因此,獲取這些資訊的替代方法是什麼?你可能會問為什麼我要去看這個?是的,在某些情況下,你可能需要查看這些信息,那時會對你會有幫助。可以使用以下7種方法進行驗證。使用/var/log/secure使用aureport工具使用.bash_logout使用chage指令使用useradd指令使用passwd指令使用last指令方式1:使用/var/l

全系統安裝如果你在系統範圍內安裝字體,那麼它可以讓所有使用者使用。此方式的最佳方法是使用官方軟體庫中的RPM軟體包。開始前開啟FedoraWorkstation中的「Software」工具,或其他使用官方倉庫的工具。選擇橫欄中選擇“Add-ons”類別。接著在該類別中選擇“Fonts”。你會看到類似下面截圖中的可用字體:當你選擇一種字體時,會出現一些細節。根據幾種情況,你可能能夠預覽字體的一些範例文字。點擊“Install”按鈕將其添加到你的系統。根據系統速度和網路頻寬,完成此過程可能需要一些

1.從網路上找到wingdings、wingdings2、wingdings3、Webdings、MTExtra這些字體2、進入主資料夾,按Ctrl+h鍵(顯示隱藏檔案),查看有沒有.fonts資料夾,如果沒有就建立一個3、把下載下來的wingdings、wingdings2、wingdings3、Webdings、MTExtra這些字體,複製到主資料夾下的.fonts資料夾裡,再去啟動wps看看還有沒有「系統缺少字體…」提醒對話框,沒有就成功了! 注意事項:wingdings、wingdin

實驗環境:OS:LinuxCentos7.4x86_641.查看目前伺服器時區&列出時區並設定時區(如已是正確時區,請略過):#timedatectl#timedatectllist-timezones#timedatectlset-timezoneAsia/Shanghai2.時間時區理解概念: GMT、UTC、CST、DSTUTC:整個地球分為二十四時區,每個時區都有自己的本地時間,在國際無線電通訊場合,為了統一起見,使用一個統一的時間,稱為通用協調時(UTC :UniversalTim

如何使用一條網線讓兩台ubuntu主機聯網1、準備主機A:ubuntu16.04主機B:ubuntu16.042、主機A有兩個網卡,一個接外網,一個與主機B相接。使用指令iwconfig可以查看主機所有網路卡。如上圖筆者的A主機(筆記本)上的網卡有:wlp2s0:這個是無線網卡。 enp1s0:有線網路卡,與B主機連接的網路卡。其它與我們無關,無需關心。 3.設定A的靜態IP編輯檔#vim/etc/network/interfaces為介面enp1s0配置靜態IP位址,如下圖(其中#==========

不同的CPU架構意味著在樹莓派上運行DOS並非唾手可得,但其實也沒多麻煩。 FreeDOS對大家來說也許並不陌生。它是一個完整、免費且對DOS相容良好的作業系統,它可以運行一些比較老舊的DOS遊戲或商用軟體,也可以開發嵌入式的應用。只要在MS-DOS上能夠運行的程序,在FreeDOS上都可以運行。身為FreeDOS的發起者和專案協調人員,許多使用者會把我當成內行人進行提問。而我最常被問到的問題是:「FreeDOS可以在樹莓派上運行嗎?」這個問題並不令人意外。畢竟Linux在樹莓派上能夠很好地運
