JVM常见调优场景

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个最大的对象,可以检查到哪几个对象占用了大量的内存。

你可能感兴趣的:(Java,jvm)