1. 监控工具
1. jvisualvm(JDK内置)
2. jconsole(JDK内置)

3. jmc(JDK内置)

4. Jprofile(第三方)
5. Eclipse Memory Analyzer
6. JvisualVM插件
2. JAVA命令行工具

2.1 jps虚拟机进程状况工具
常用的几个参数:
-l 输出java应用程序的main class的完整包
-q 仅显示pid,不显示其它任何相关信息
-m 输出传递给main方法的参数
-v 输出传递给JVM的参数。在诊断JVM相关问题的时候,这个参数可以查看JVM相关参数的设置
2.2 jstat虚拟机统计信息监视工具
jstat [ generalOption | outputOptions vmid [interval[s|ms] [count]] ]
vmid是虚拟机ID,在Linux/Unix系统上一般就是进程ID。interval是采样时间间隔。count是采样数目。比如下面输出的是GC信息,采样时间间隔为250ms,采样数为4:
| 1 2 3 4 5 6 |
|
要明白上面各列的意义,先看JVM堆内存布局:

| 1 2 |
|
现在来解释各列含义:
| 1 2 3 4 5 6 7 |
|

2.3 jinfo配置信息工具
观察运行中的java程序的运行环境参数:参数包括Java System属性和JVM命令行参数
实例:jinfo 2083
其中2083就是j
JVM监控与故障处理实战指南

本文详细介绍了JVM的各种监控工具如jps、jstat、jinfo、jmap和jstack的使用,以及如何通过这些工具进行内存、线程、热点分析和快照查看。还讲解了JAVA基础命令,如javac、jar和javadoc,并讨论了常见的JVM问题,如内存泄露、高GC消耗和CPU使用率高的故障定位与处理方法。通过阅读,读者能掌握JVM监控与故障处理的基本技能。
最低0.47元/天 解锁文章
847

被折叠的 条评论
为什么被折叠?



