1. JVM常用命令
jps:获取当前正在运行的线程。
jinfo:可以输出并修改运行时的java 进程的opts。
jmap:得到运行java程序的内存分配的详细情况。例如实例个数,大小等。
jstat:可以观察到classloader,compiler,gc相关信息。可以时时监控资源和性能。
jconsole:java GUI监视工具,可以以图表化的形式显示各种数据。并可通过远程连接监视远程的服务器VM。
jvisualvm:jvm GUI监视工具。
jstack:能得到运行java程序线程的运行情况。
2. 常见调优场景
1.Cpu占用过高
先查出哪个线程占用Cpu资源,再使用jstack
查看正在运行的线程,将线程编号换算成16进制找到对应线程排查
# 检测后台进程对Cpu和内存的占用情况
top
# 输出所有进程线程的CPU占用百分比
ps H -eo pid, tid, %cpu | grep [进程号]
# 输出详细信息
jstack [进程号]
2.排查死锁
使用jstack
输出详细信息,最后会有Found one java-level deadlock
,表示有死锁产生,还会给你标注哪两个线程产生了死锁。
3.执行GC之后内存占用依然很高
使用jvisualvm打开GUI面板,监视 -> 堆 Dump,截取一个内存快照。
检查 -> 查找前20个最大的对象,可以检查到哪几个对象占用了大量的内存。