jstat是jdk的內置命令,用于監(jiān)控jvm內存及gc活動的工具
用法如下:
- jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
-t :代表時間粗
-h<lines>:即-h跟數(shù)字,代表隔幾行顯示標題
vmid :代表vm進程id
interval:代表監(jiān)控間隔時間段,默認毫秒做單位
count:代表取數(shù)次數(shù)
例:jstat -gcutil -t -h5 123456 1000 100
表示每1000毫秒收集一次jvm內存和gc信息,共收集100次,每隔5行顯示一次標題,且標題行帶時間戳
- jstat -gc pid
顯示gc的信息,查看gc的次數(shù),及時間。
- jstat -gccapacity pid
VM分代內存的使用和占用大小。
- jstat -gcutil pid
統(tǒng)計gc信息統(tǒng)計。
- jstat -gcnew pid
年輕代對象的信息。
- jstat -gcnewcapacity pid
年輕代對象的信息及其占用量。
- jstat -gcold pid
old代對象的信息。
- jstat -gcoldcapacity pid
old代對象的信息。
- jstat -gcpermcapacity pid
perm對象的信息及其占用量。
- jstat -class pid
顯示加載class的數(shù)量,及所占空間等信息。
- jstat -compiler pid
顯示VM實時編譯的數(shù)量等信息。
- jstat -printcompilation pid
當前VM執(zhí)行的信息。
一些術語的中文解釋:
S0C:年輕代中第一個survivor(幸存區(qū))的容量 (字節(jié))
S1C:年輕代中第二個survivor(幸存區(qū))的容量 (字節(jié))
S0U:年輕代中第一個survivor(幸存區(qū))目前已使用空間 (字節(jié))
S1U:年輕代中第二個survivor(幸存區(qū))目前已使用空間 (字節(jié))
EC:年輕代中Eden(伊甸園)的容量 (字節(jié))
EU:年輕代中Eden(伊甸園)目前已使用空間 (字節(jié))
OC:Old代的容量 (字節(jié))
OU:Old代目前已使用空間 (字節(jié))
PC:Perm(持久代)的容量 (字節(jié))
PU:Perm(持久代)目前已使用空間 (字節(jié))
YGC:從應用程序啟動到采樣時年輕代中gc次數(shù)
YGCT:從應用程序啟動到采樣時年輕代中gc所用時間(s)
FGC:從應用程序啟動到采樣時old代(全gc)gc次數(shù)
FGCT:從應用程序啟動到采樣時old代(全gc)gc所用時間(s)
GCT:從應用程序啟動到采樣時gc用的總時間(s)
NGCMN:年輕代(young)中初始化(最小)的大小 (字節(jié))
NGCMX:年輕代(young)的最大容量 (字節(jié))
NGC:年輕代(young)中當前的容量 (字節(jié))
OGCMN:old代中初始化(最小)的大小 (字節(jié))
OGCMX:old代的最大容量 (字節(jié))
OGC:old代當前新生成的容量 (字節(jié))
PGCMN:perm代中初始化(最小)的大小 (字節(jié))
PGCMX:perm代的最大容量 (字節(jié))
PGC:perm代當前新生成的容量 (字節(jié))
S0:年輕代中第一個survivor(幸存區(qū))已使用的占當前容量百分比
S1:年輕代中第二個survivor(幸存區(qū))已使用的占當前容量百分比
E:年輕代中Eden(伊甸園)已使用的占當前容量百分比
O:old代已使用的占當前容量百分比
P:perm代已使用的占當前容量百分比
S0CMX:年輕代中第一個survivor(幸存區(qū))的最大容量 (字節(jié))
S1CMX :年輕代中第二個survivor(幸存區(qū))的最大容量 (字節(jié))
ECMX:年輕代中Eden(伊甸園)的最大容量 (字節(jié))
DSS:當前需要survivor(幸存區(qū))的容量 (字節(jié))(Eden區(qū)已滿)
TT: 持有次數(shù)限制
MTT : 最大持有次數(shù)限制