一、top(Linux命令)
執(zhí)行top命令:? (查看進(jìn)程15477的詳細(xì)情況,下文用到)

系統(tǒng)信息(前五行):
第1行:Top 任務(wù)隊(duì)列信息(系統(tǒng)運(yùn)行狀態(tài)及平均負(fù)載),與uptime命令結(jié)果相同。
第1段:系統(tǒng)當(dāng)前時(shí)間,例如:16:07:37
第2段:系統(tǒng)運(yùn)行時(shí)間,未重啟的時(shí)間,時(shí)間越長(zhǎng)系統(tǒng)越穩(wěn)定。
格式:up xx days, HH:MM
例如:241 days, 20:11, 表示連續(xù)運(yùn)行了241天20小時(shí)11分鐘
第3段:當(dāng)前登錄用戶數(shù),例如:1 user,表示當(dāng)前只有1個(gè)用戶登錄
第4段:系統(tǒng)負(fù)載,即任務(wù)隊(duì)列的平均長(zhǎng)度,3個(gè)數(shù)值分別統(tǒng)計(jì)最近1,5,15分鐘的系統(tǒng)平均負(fù)載
系統(tǒng)平均負(fù)載:?jiǎn)魏薈PU情況下,0.00 表示沒(méi)有任何負(fù)荷,1.00表示剛好滿負(fù)荷,超過(guò)1側(cè)表示超負(fù)荷,理想值是0.7;
多核CPU負(fù)載:CPU核數(shù) * 理想值0.7 = 理想負(fù)荷,例如:4核CPU負(fù)載不超過(guò)2.8何表示沒(méi)有出現(xiàn)高負(fù)載。
第2行:Tasks 進(jìn)程相關(guān)信息
第1段:進(jìn)程總數(shù),例如:Tasks: 231 total, 表示總共運(yùn)行231個(gè)進(jìn)程
第2段:正在運(yùn)行的進(jìn)程數(shù),例如:1 running,
第3段:睡眠的進(jìn)程數(shù),例如:230 sleeping,
第4段:停止的進(jìn)程數(shù),例如:0 stopped,
第5段:僵尸進(jìn)程數(shù),例如:0 zombie
第3行:Cpus CPU相關(guān)信息,如果是多核CPU,按數(shù)字1可顯示各核CPU信息,此時(shí)1行將轉(zhuǎn)為Cpu核數(shù)行,數(shù)字1可以來(lái)回切換。
第1段:us 用戶空間占用CPU百分比,例如:Cpu(s): 12.7%us,
第2段:sy 內(nèi)核空間占用CPU百分比,例如:8.4%sy,
第3段:ni 用戶進(jìn)程空間內(nèi)改變過(guò)優(yōu)先級(jí)的進(jìn)程占用CPU百分比,例如:0.0%ni,
第4段:id 空閑CPU百分比,例如:77.1%id,
第5段:wa 等待輸入輸出的CPU時(shí)間百分比,例如:0.0%wa,
第6段:hi CPU服務(wù)于硬件中斷所耗費(fèi)的時(shí)間總額,例如:0.0%hi,
第7段:si CPU服務(wù)軟中斷所耗費(fèi)的時(shí)間總額,例如:1.8%si,
第8段:st Steal time 虛擬機(jī)被hypervisor偷去的CPU時(shí)間(如果當(dāng)前處于一個(gè)hypervisor下的vm,實(shí)際上hypervisor也是要消耗一部分CPU處理時(shí)間的)
第4行:Mem 內(nèi)存相關(guān)信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)
第1段:物理內(nèi)存總量,例如:Mem: 12196436k total,
第2段:使用的物理內(nèi)存總量,例如:12056552k used,
第3段:空閑內(nèi)存總量,例如:Mem: 139884k free,
第4段:用作內(nèi)核緩存的內(nèi)存量,例如:64564k buffers
第5行:Swap 交換分區(qū)相關(guān)信息(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached)
第1段:交換區(qū)總量,例如:Swap: 2097144k total,
第2段:使用的交換區(qū)總量,例如:151016k used,
第3段:空閑交換區(qū)總量,例如:1946128k free,
第4段:緩沖的交換區(qū)總量,3120236k cached
進(jìn)程信息:
在top命令中按f按可以查看顯示的列信息,按對(duì)應(yīng)字母來(lái)開(kāi)啟/關(guān)閉列,大寫字母表示開(kāi)啟,小寫字母表示關(guān)閉。帶*號(hào)的是默認(rèn)列。
A: PID = (Process Id) 進(jìn)程Id;
E: USER = (User Name) 進(jìn)程所有者的用戶名;
H: PR = (Priority) 優(yōu)先級(jí)
I: NI = (Nice value) nice值。負(fù)值表示高優(yōu)先級(jí),正值表示低優(yōu)先級(jí)
O: VIRT = (Virtual Image (kb)) 進(jìn)程使用的虛擬內(nèi)存總量,單位kb。VIRT=SWAP+RES
Q: RES = (Resident size (kb)) 進(jìn)程使用的、未被換出的物理內(nèi)存大小,單位kb。RES=CODE+DATA
T: SHR = (Shared Mem size (kb)) 共享內(nèi)存大小,單位kb
W: S = (Process Status) 進(jìn)程狀態(tài)。D=不可中斷的睡眠狀態(tài),R=運(yùn)行,S=睡眠,T=跟蹤/停止,Z=僵尸進(jìn)程
K: %CPU = (CPU usage) 上次更新到現(xiàn)在的CPU時(shí)間占用百分比
N: %MEM = (Memory usage (RES)) 進(jìn)程使用的物理內(nèi)存百分比
M: TIME+ = (CPU Time, hundredths) 進(jìn)程使用的CPU時(shí)間總計(jì),單位1/100秒
b: PPID = (Parent Process Pid) 父進(jìn)程Id
c: RUSER = (Real user name)
d: UID = (User Id) 進(jìn)程所有者的用戶id
f: GROUP = (Group Name) 進(jìn)程所有者的組名
g: TTY = (Controlling Tty) 啟動(dòng)進(jìn)程的終端名。不是從終端啟動(dòng)的進(jìn)程則顯示為 ?
j: P = (Last used cpu (SMP)) 最后使用的CPU,僅在多CPU環(huán)境下有意義
p: SWAP = (Swapped size (kb)) 進(jìn)程使用的虛擬內(nèi)存中,被換出的大小,單位kb
l: TIME = (CPU Time) 進(jìn)程使用的CPU時(shí)間總計(jì),單位秒
r: CODE = (Code size (kb)) 可執(zhí)行代碼占用的物理內(nèi)存大小,單位kb
s: DATA = (Data+Stack size (kb)) 可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小,單位kb
u: nFLT = (Page Fault count) 頁(yè)面錯(cuò)誤次數(shù)
v: nDRT = (Dirty Pages count) 最后一次寫入到現(xiàn)在,被修改過(guò)的頁(yè)面數(shù)
y: WCHAN = (Sleeping in Function) 若該進(jìn)程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名
z: Flags = (Task Flags <sched.h>) 任務(wù)標(biāo)志,參考 sched.h
X: COMMAND = (Command name/line) 命令名/命令行
參考? Linux性能分析工具top命令詳解
執(zhí)行top -Hp PID,如 top -Hp 15477
查看某進(jìn)程中的線程? 注:此時(shí)PID是線程id
如線程15571有異常需要查看,使用jstack打印堆棧,查看線程15571狀態(tài)(15571 16進(jìn)制=3cd3)

二、jstack
參考 java命令--jstack 工具
? Java命令學(xué)習(xí)系列(二)——Jstack
需要到JDK安裝目錄下使用(可通過(guò)ps x查看java進(jìn)程,得到j(luò)dk安裝目錄)
./jstack PID(進(jìn)程id)? ./jstack 15477
紅框中即為線程15571(16進(jìn)制=3cd3) 狀態(tài)

分析jstack日志:

監(jiān)視器Monitor:
Monitor是 Java中用以實(shí)現(xiàn)線程之間的互斥與協(xié)作的主要手段,它可以看成是對(duì)象或者 Class的鎖。
每一個(gè)對(duì)象都有,也僅有一個(gè) monitor。
下面這個(gè)圖,描述了線程和Monitor之間關(guān)系,以及線程的狀態(tài)轉(zhuǎn)換:

進(jìn)入?yún)^(qū)(Entrt Set):表示線程通過(guò)synchronized要求獲取對(duì)象的鎖。如果對(duì)象被鎖住,則進(jìn)入擁有者;否則在進(jìn)入?yún)^(qū)等待。一旦對(duì)象鎖被其他線程釋放,立即參與競(jìng)爭(zhēng)。
擁有者(The Owner):表示某一線程成功競(jìng)爭(zhēng)到對(duì)象鎖。
等待區(qū)(Wait Set):表示線程通過(guò)對(duì)象的object.wait()方法,釋放對(duì)象的鎖,并在等待區(qū)等待被喚醒。
從圖中可以看出,一個(gè) Monitor在某個(gè)時(shí)刻,只能被一個(gè)線程擁有,該線程就是 Active Thread,而其它線程都是 Waiting Thread,分別在兩個(gè)隊(duì)列 Entry Set和 Wait Set里面等候。
在 Entry Set中等待的線程動(dòng)作是 Waiting for monitor entry。
在 Wait Set中等待的線程動(dòng)作是 in Object.wait()。當(dāng)一個(gè)線程申請(qǐng)進(jìn)入臨界區(qū)時(shí),它就進(jìn)入了 Entry Set隊(duì)列。
(我們稱被 synchronized保護(hù)起來(lái)的代碼段為臨界區(qū)。當(dāng)一個(gè)線程申請(qǐng)進(jìn)入臨界區(qū)時(shí),它就進(jìn)入了 “Entry Set ”隊(duì)列)
線程狀態(tài):
NEW:未啟動(dòng)的。不會(huì)出現(xiàn)在Dump中。
RUNNABLE:在虛擬機(jī)內(nèi)執(zhí)行的,運(yùn)行中狀態(tài)。The Owner區(qū)
BLOCKED:受阻塞并等待監(jiān)視器鎖。在Entry Set區(qū)等鎖。
WATING:無(wú)限期等待另一個(gè)線程執(zhí)行特定操作。在Wait Set區(qū)等待某個(gè)condition或monitor發(fā)生,一般停留在wait()等語(yǔ)句里。
TIMED_WATING:有時(shí)限的等待另一個(gè)線程的特定操作。在Wait Set區(qū)和WAITING的區(qū)別是wait() 等語(yǔ)句加上了時(shí)間限制 wait(timeout)。
TERMINATED:已退出的。
調(diào)用修飾
表示線程在方法調(diào)用時(shí),額外的重要的操作。修飾上方的方法調(diào)用。
locked <地址> 目標(biāo):使用synchronized申請(qǐng)對(duì)象鎖成功,監(jiān)視器的擁有者。The Owner區(qū)。
waiting to lock <地址> 目標(biāo):使用synchronized申請(qǐng)對(duì)象鎖未成功,在Entry Set區(qū)等鎖。線程狀態(tài)為Blocked
waiting on <地址> 目標(biāo):使用synchronized申請(qǐng)對(duì)象鎖成功后,釋放鎖,在Wait Set區(qū)等鎖。線程狀態(tài)為WAITING或TIMED_WATING
parking to wait for <地址> 目標(biāo):調(diào)用了park(),在Wait Set區(qū),等待許可。
(park是基本的線程阻塞原語(yǔ),不通過(guò)監(jiān)視器在對(duì)象上阻塞。
park: 進(jìn)入WAITING狀態(tài),對(duì)比wait不需要獲得鎖就可以讓線程WAITING,通過(guò)unpark喚醒)
線程動(dòng)作
線程狀態(tài)產(chǎn)生的原因。
runnable:The Owner區(qū),狀態(tài)RUNNABLE
in Object.wait():調(diào)用wait(),Wait Set區(qū),狀態(tài)為WAITING或TIMED_WAITING,修飾waiting on
waiting for monitor entry:等鎖,Entry Set區(qū),狀態(tài)BLOCKED,修飾waiting to lock
waiting on condition:因某種條件被park,Wait Set區(qū),狀態(tài)為parking to wait for
sleeping:休眠的線程,調(diào)用了Thread.sleep()
總結(jié)
1、查看線程dump,先看線程狀態(tài)/線程動(dòng)作(比較直觀),可以確定線程目前處于哪個(gè)階段。然后看調(diào)用修飾及鎖情況,基本就可以確定次線程是否有問(wèn)題;
2、可以短時(shí)間(可能有問(wèn)題的時(shí)間段)內(nèi)多次打印線程快照,然后查看可能有問(wèn)題的某一線程在這幾次的情況,可以有效查找問(wèn)題。
三、jps
類似Linux命令ps
參考 Java命令學(xué)習(xí)系列(一)——Jps
./jps

./jps -q

./jps -m

./jps -l

./jps -v

一、top(Linux命令)
執(zhí)行top命令:? (查看進(jìn)程15477的詳細(xì)情況,下文用到)

系統(tǒng)信息(前五行):
第1行:Top 任務(wù)隊(duì)列信息(系統(tǒng)運(yùn)行狀態(tài)及平均負(fù)載),與uptime命令結(jié)果相同。
第1段:系統(tǒng)當(dāng)前時(shí)間,例如:16:07:37
第2段:系統(tǒng)運(yùn)行時(shí)間,未重啟的時(shí)間,時(shí)間越長(zhǎng)系統(tǒng)越穩(wěn)定。
格式:up xx days, HH:MM
例如:241 days, 20:11, 表示連續(xù)運(yùn)行了241天20小時(shí)11分鐘
第3段:當(dāng)前登錄用戶數(shù),例如:1 user,表示當(dāng)前只有1個(gè)用戶登錄
第4段:系統(tǒng)負(fù)載,即任務(wù)隊(duì)列的平均長(zhǎng)度,3個(gè)數(shù)值分別統(tǒng)計(jì)最近1,5,15分鐘的系統(tǒng)平均負(fù)載
系統(tǒng)平均負(fù)載:?jiǎn)魏薈PU情況下,0.00 表示沒(méi)有任何負(fù)荷,1.00表示剛好滿負(fù)荷,超過(guò)1側(cè)表示超負(fù)荷,理想值是0.7;
多核CPU負(fù)載:CPU核數(shù) * 理想值0.7 = 理想負(fù)荷,例如:4核CPU負(fù)載不超過(guò)2.8何表示沒(méi)有出現(xiàn)高負(fù)載。
第2行:Tasks 進(jìn)程相關(guān)信息
第1段:進(jìn)程總數(shù),例如:Tasks: 231 total, 表示總共運(yùn)行231個(gè)進(jìn)程
第2段:正在運(yùn)行的進(jìn)程數(shù),例如:1 running,
第3段:睡眠的進(jìn)程數(shù),例如:230 sleeping,
第4段:停止的進(jìn)程數(shù),例如:0 stopped,
第5段:僵尸進(jìn)程數(shù),例如:0 zombie
第3行:Cpus CPU相關(guān)信息,如果是多核CPU,按數(shù)字1可顯示各核CPU信息,此時(shí)1行將轉(zhuǎn)為Cpu核數(shù)行,數(shù)字1可以來(lái)回切換。
第1段:us 用戶空間占用CPU百分比,例如:Cpu(s): 12.7%us,
第2段:sy 內(nèi)核空間占用CPU百分比,例如:8.4%sy,
第3段:ni 用戶進(jìn)程空間內(nèi)改變過(guò)優(yōu)先級(jí)的進(jìn)程占用CPU百分比,例如:0.0%ni,
第4段:id 空閑CPU百分比,例如:77.1%id,
第5段:wa 等待輸入輸出的CPU時(shí)間百分比,例如:0.0%wa,
第6段:hi CPU服務(wù)于硬件中斷所耗費(fèi)的時(shí)間總額,例如:0.0%hi,
第7段:si CPU服務(wù)軟中斷所耗費(fèi)的時(shí)間總額,例如:1.8%si,
第8段:st Steal time 虛擬機(jī)被hypervisor偷去的CPU時(shí)間(如果當(dāng)前處于一個(gè)hypervisor下的vm,實(shí)際上hypervisor也是要消耗一部分CPU處理時(shí)間的)
第4行:Mem 內(nèi)存相關(guān)信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)
第1段:物理內(nèi)存總量,例如:Mem: 12196436k total,
第2段:使用的物理內(nèi)存總量,例如:12056552k used,
第3段:空閑內(nèi)存總量,例如:Mem: 139884k free,
第4段:用作內(nèi)核緩存的內(nèi)存量,例如:64564k buffers
第5行:Swap 交換分區(qū)相關(guān)信息(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached)
第1段:交換區(qū)總量,例如:Swap: 2097144k total,
第2段:使用的交換區(qū)總量,例如:151016k used,
第3段:空閑交換區(qū)總量,例如:1946128k free,
第4段:緩沖的交換區(qū)總量,3120236k cached
進(jìn)程信息:
在top命令中按f按可以查看顯示的列信息,按對(duì)應(yīng)字母來(lái)開(kāi)啟/關(guān)閉列,大寫字母表示開(kāi)啟,小寫字母表示關(guān)閉。帶*號(hào)的是默認(rèn)列。
A: PID = (Process Id) 進(jìn)程Id;
E: USER = (User Name) 進(jìn)程所有者的用戶名;
H: PR = (Priority) 優(yōu)先級(jí)
I: NI = (Nice value) nice值。負(fù)值表示高優(yōu)先級(jí),正值表示低優(yōu)先級(jí)
O: VIRT = (Virtual Image (kb)) 進(jìn)程使用的虛擬內(nèi)存總量,單位kb。VIRT=SWAP+RES
Q: RES = (Resident size (kb)) 進(jìn)程使用的、未被換出的物理內(nèi)存大小,單位kb。RES=CODE+DATA
T: SHR = (Shared Mem size (kb)) 共享內(nèi)存大小,單位kb
W: S = (Process Status) 進(jìn)程狀態(tài)。D=不可中斷的睡眠狀態(tài),R=運(yùn)行,S=睡眠,T=跟蹤/停止,Z=僵尸進(jìn)程
K: %CPU = (CPU usage) 上次更新到現(xiàn)在的CPU時(shí)間占用百分比
N: %MEM = (Memory usage (RES)) 進(jìn)程使用的物理內(nèi)存百分比
M: TIME+ = (CPU Time, hundredths) 進(jìn)程使用的CPU時(shí)間總計(jì),單位1/100秒
b: PPID = (Parent Process Pid) 父進(jìn)程Id
c: RUSER = (Real user name)
d: UID = (User Id) 進(jìn)程所有者的用戶id
f: GROUP = (Group Name) 進(jìn)程所有者的組名
g: TTY = (Controlling Tty) 啟動(dòng)進(jìn)程的終端名。不是從終端啟動(dòng)的進(jìn)程則顯示為 ?
j: P = (Last used cpu (SMP)) 最后使用的CPU,僅在多CPU環(huán)境下有意義
p: SWAP = (Swapped size (kb)) 進(jìn)程使用的虛擬內(nèi)存中,被換出的大小,單位kb
l: TIME = (CPU Time) 進(jìn)程使用的CPU時(shí)間總計(jì),單位秒
r: CODE = (Code size (kb)) 可執(zhí)行代碼占用的物理內(nèi)存大小,單位kb
s: DATA = (Data+Stack size (kb)) 可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小,單位kb
u: nFLT = (Page Fault count) 頁(yè)面錯(cuò)誤次數(shù)
v: nDRT = (Dirty Pages count) 最后一次寫入到現(xiàn)在,被修改過(guò)的頁(yè)面數(shù)
y: WCHAN = (Sleeping in Function) 若該進(jìn)程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名
z: Flags = (Task Flags <sched.h>) 任務(wù)標(biāo)志,參考 sched.h
X: COMMAND = (Command name/line) 命令名/命令行
參考? Linux性能分析工具top命令詳解
執(zhí)行top -Hp PID,如 top -Hp 15477
查看某進(jìn)程中的線程? 注:此時(shí)PID是線程id
如線程15571有異常需要查看,使用jstack打印堆棧,查看線程15571狀態(tài)(15571 16進(jìn)制=3cd3)

二、jstack
參考 java命令--jstack 工具
? Java命令學(xué)習(xí)系列(二)——Jstack
需要到JDK安裝目錄下使用(可通過(guò)ps x查看java進(jìn)程,得到j(luò)dk安裝目錄)
./jstack PID(進(jìn)程id)? ./jstack 15477
紅框中即為線程15571(16進(jìn)制=3cd3) 狀態(tài)

分析jstack日志:

監(jiān)視器Monitor:
Monitor是 Java中用以實(shí)現(xiàn)線程之間的互斥與協(xié)作的主要手段,它可以看成是對(duì)象或者 Class的鎖。
每一個(gè)對(duì)象都有,也僅有一個(gè) monitor。
下面這個(gè)圖,描述了線程和Monitor之間關(guān)系,以及線程的狀態(tài)轉(zhuǎn)換:

進(jìn)入?yún)^(qū)(Entrt Set):表示線程通過(guò)synchronized要求獲取對(duì)象的鎖。如果對(duì)象被鎖住,則進(jìn)入擁有者;否則在進(jìn)入?yún)^(qū)等待。一旦對(duì)象鎖被其他線程釋放,立即參與競(jìng)爭(zhēng)。
擁有者(The Owner):表示某一線程成功競(jìng)爭(zhēng)到對(duì)象鎖。
等待區(qū)(Wait Set):表示線程通過(guò)對(duì)象的object.wait()方法,釋放對(duì)象的鎖,并在等待區(qū)等待被喚醒。
從圖中可以看出,一個(gè) Monitor在某個(gè)時(shí)刻,只能被一個(gè)線程擁有,該線程就是 Active Thread,而其它線程都是 Waiting Thread,分別在兩個(gè)隊(duì)列 Entry Set和 Wait Set里面等候。
在 Entry Set中等待的線程動(dòng)作是 Waiting for monitor entry。
在 Wait Set中等待的線程動(dòng)作是 in Object.wait()。當(dāng)一個(gè)線程申請(qǐng)進(jìn)入臨界區(qū)時(shí),它就進(jìn)入了 Entry Set隊(duì)列。
(我們稱被 synchronized保護(hù)起來(lái)的代碼段為臨界區(qū)。當(dāng)一個(gè)線程申請(qǐng)進(jìn)入臨界區(qū)時(shí),它就進(jìn)入了 “Entry Set ”隊(duì)列)
線程狀態(tài):
NEW:未啟動(dòng)的。不會(huì)出現(xiàn)在Dump中。
RUNNABLE:在虛擬機(jī)內(nèi)執(zhí)行的,運(yùn)行中狀態(tài)。The Owner區(qū)
BLOCKED:受阻塞并等待監(jiān)視器鎖。在Entry Set區(qū)等鎖。
WATING:無(wú)限期等待另一個(gè)線程執(zhí)行特定操作。在Wait Set區(qū)等待某個(gè)condition或monitor發(fā)生,一般停留在wait()等語(yǔ)句里。
TIMED_WATING:有時(shí)限的等待另一個(gè)線程的特定操作。在Wait Set區(qū)和WAITING的區(qū)別是wait() 等語(yǔ)句加上了時(shí)間限制 wait(timeout)。
TERMINATED:已退出的。
調(diào)用修飾
表示線程在方法調(diào)用時(shí),額外的重要的操作。修飾上方的方法調(diào)用。
locked <地址> 目標(biāo):使用synchronized申請(qǐng)對(duì)象鎖成功,監(jiān)視器的擁有者。The Owner區(qū)。
waiting to lock <地址> 目標(biāo):使用synchronized申請(qǐng)對(duì)象鎖未成功,在Entry Set區(qū)等鎖。線程狀態(tài)為Blocked
waiting on <地址> 目標(biāo):使用synchronized申請(qǐng)對(duì)象鎖成功后,釋放鎖,在Wait Set區(qū)等鎖。線程狀態(tài)為WAITING或TIMED_WATING
parking to wait for <地址> 目標(biāo):調(diào)用了park(),在Wait Set區(qū),等待許可。
(park是基本的線程阻塞原語(yǔ),不通過(guò)監(jiān)視器在對(duì)象上阻塞。
park: 進(jìn)入WAITING狀態(tài),對(duì)比wait不需要獲得鎖就可以讓線程WAITING,通過(guò)unpark喚醒)
線程動(dòng)作
線程狀態(tài)產(chǎn)生的原因。
runnable:The Owner區(qū),狀態(tài)RUNNABLE
in Object.wait():調(diào)用wait(),Wait Set區(qū),狀態(tài)為WAITING或TIMED_WAITING,修飾waiting on
waiting for monitor entry:等鎖,Entry Set區(qū),狀態(tài)BLOCKED,修飾waiting to lock
waiting on condition:因某種條件被park,Wait Set區(qū),狀態(tài)為parking to wait for
sleeping:休眠的線程,調(diào)用了Thread.sleep()
總結(jié)
1、查看線程dump,先看線程狀態(tài)/線程動(dòng)作(比較直觀),可以確定線程目前處于哪個(gè)階段。然后看調(diào)用修飾及鎖情況,基本就可以確定次線程是否有問(wèn)題;
2、可以短時(shí)間(可能有問(wèn)題的時(shí)間段)內(nèi)多次打印線程快照,然后查看可能有問(wèn)題的某一線程在這幾次的情況,可以有效查找問(wèn)題。
三、jps
類似Linux命令ps
參考 Java命令學(xué)習(xí)系列(一)——Jps
./jps

./jps -q

./jps -m

./jps -l

./jps -v

四、jmap
參考? Java命令學(xué)習(xí)系列(三)——Jmap
? ? java命令--jmap命令使用
jmap -heap PID:堆使用情況
jmap -histo PID:對(duì)象情況
(jmap -histo:live 這個(gè)命令執(zhí)行,JVM會(huì)先觸發(fā)gc,然后再統(tǒng)計(jì)信息
? 重點(diǎn)看項(xiàng)目上的類:[C是字符串?dāng)?shù)組,String用;[B是字節(jié)數(shù)組,網(wǎng)絡(luò)層用到。這兩個(gè)比較大一般沒(méi)關(guān)系
[C is a char[]
[S is a short[]
[I is a int[]
[B is a byte[]
[[I is a int[][]
)
技術(shù)在于學(xué)習(xí) 在于實(shí)踐 在于總結(jié) 在于分享
四、jmap
參考? Java命令學(xué)習(xí)系列(三)——Jmap
? ? java命令--jmap命令使用
jmap -heap PID:堆使用情況
jmap -histo PID:對(duì)象情況
(jmap -histo:live 這個(gè)命令執(zhí)行,JVM會(huì)先觸發(fā)gc,然后再統(tǒng)計(jì)信息
? 重點(diǎn)看項(xiàng)目上的類:[C是字符串?dāng)?shù)組,String用;[B是字節(jié)數(shù)組,網(wǎng)絡(luò)層用到。這兩個(gè)比較大一般沒(méi)關(guān)系
[C is a char[]
[S is a short[]
[I is a int[]
[B is a byte[]
[[I is a int[][]
)
技術(shù)在于學(xué)習(xí) 在于實(shí)踐 在于總結(jié) 在于分享
歡迎工作一到五年的Java工程師朋友們加入Java架構(gòu)開(kāi)發(fā): 854393687
群內(nèi)提供免費(fèi)的Java架構(gòu)學(xué)習(xí)資料(里面有高可用、高并發(fā)、高性能及分布式、Jvm性能調(diào)優(yōu)、Spring源碼,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個(gè)知識(shí)點(diǎn)的架構(gòu)資料)合理利用自己每一分每一秒的時(shí)間來(lái)學(xué)習(xí)提升自己,不要再用"沒(méi)有時(shí)間“來(lái)掩飾自己思想上的懶惰!趁年輕,使勁拼,給未來(lái)的自己一個(gè)交代!