JDK内置工具使用(性能分析)
作者:互联网
# 1、JPS
**1、jps -lvm**:用于查看当前机器上已装载的jvm
# 2、jstack
jstack命令主要用来查看Java线程的调用堆栈的,可以用来分析线程问题(如死锁)
**1、jstack -l pid:** 查看某个进程的堆栈信息
![在这里插入图片描述](https://www.icode9.com/i/ll/?i=20190214130559650.png?,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NpbmF0XzQxOTE3MzA2,size_16,color_FFFFFF,t_70)
dump 文件里,值得关注的线程状态有:
> 1. 死锁:Deadlock(重点关注)
>2. 执行中:Runnable
>3. 等待资源:Waiting on condition(重点关注)
>4. 等待获取监视器:Waiting on monitor entry(重点关注)
>5. 暂停:Suspended
>6. 对象等待中:Object.wait() 或 TIMED_WAITING
>7. 阻塞:Blocked(重点关注)
>8. 停止:Parked
**2、 jstack -l pid >文件名** :生成线程快照
# 3、jmap
jmap命令可以获得运行中的jvm的堆的快照,从而可以离线分析堆,以检查内存泄漏,检查一些严重影响性能的大对象的创建,检查系统中什么对象最多,各种对象所占内存的大小等等
**1、jmap -heap PID**:打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况
![在这里插入图片描述](https://www.icode9.com/i/ll/?i=20190305153440190.png?,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NpbmF0XzQxOTE3MzA2,size_16,color_FFFFFF,t_70)
![在这里插入图片描述](https://www.icode9.com/i/ll/?i=20190305153502827.png?,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NpbmF0XzQxOTE3MzA2,size_16,color_FFFFFF,t_70)
**2、jmap -histo pid**:展示class的内存情况
**3、jmap -histo:live pid>a.log**
可以观察heap中所有对象的情况(heap中所有生存的对象的情况)。包括对象数量和所占空间大小。 可以将其保存到文本中去,在一段时间后,使用文本对比工具,可以对比出GC回收了哪些对象。
**3、jmap -dump:format=b,file=文件名.dump PID**:生成内存dump文件
该命令通常用来分析内存泄漏OOM,通常做法是:
参考:https://mp.csdn.net/mdeditor/87294188#
# 4、jstat
Jstat用于查看gc垃圾回收使用情况:
- 类的加载及卸载情况
- 查看新生代、老生代及持久代的垃圾收集情况,包括垃圾回收的次数及垃圾回收所占用的时间
![jstat \[-option\] pid \[<interval> \[<count>\]\]](https://www.icode9.com/i/ll/?i=20190218174753585.png)
option:我们经常使用的选项有gc、gcutil
vmid:java进程id
interval:间隔时间,单位为毫秒
count:打印次数
**1、jstat -gcutil 15774 1000 10**
![在这里插入图片描述](https://www.icode9.com/i/ll/?i=20190305150557230.png)
s0:年轻代中第一个survivor已使用的占当前容量百分比
s1:年轻代中第二个survivor已使用的占当前容量百分比
E:年轻代中Eden已使用的占当前容量百分比
O:老年代中已使用的占当前容量百分比
P:永久代中已使用的占当前容量百分比
**2、jstat -gc 15774 1000 10**
![在这里插入图片描述](https://www.icode9.com/i/ll/?i=20190305150923129.png)
S0C:年轻代第一个survivor的容量(字节)
S1C:年轻代第二个survivor的容量(字节)
S0U:年轻代第一个survivor已使用的容量(字节)
S1U:年轻代第二个survivor已使用的容量(字节)
EC:年轻代中Eden的空间(字节)
EU:年代代中Eden已使用的空间(字节)
OC:老年代的容量(字节)
OU:老年代中已使用的空间(字节)
PC:永久代的容量
PU:永久代已使用的容量
YGC:从应用程序启动到采样时年轻代中GC的次数
YGCT:从应用程序启动到采样时年轻代中GC所使用的时间(单位:S)
FGC:从应用程序启动到采样时老年代中GC(FULL GC)的次数
FGCT:从应用程序启动到采样时老年代中GC所使用的时间(单位:S)
转:https://www.cnblogs.com/kongzhongqijing/articles/3621163.html
标签:内置,容量,代中,性能,JDK,GC,https,使用,字节 来源: https://www.cnblogs.com/heishuichenzhou/p/10609085.html