查看PID信息
首先启动一个服务
使用jps 和 jps -l 的区别,使用jps -l 能够显示出服务的名称
熟悉JVM调优中常用的工具JMAP、JSTAT和JSTACK
JMAP、JSTAT和JSTACK是Java开发中常用的工具,用于分析和调试Java应用程序。它们的使用场景如下:
综上所述,JMAP适用于内存分析,JSTAT适用于性能监控,JSTACK适用于线程分析。根据具体的问题和需求,选择合适的工具可以更好地帮助开发人员进行调试和优化。
JMAP的使用
JMAP是一个命令行工具,用于生成Java堆转储快照。
以下是JMAP的使用方法和常用属性的解析:
使用方法:
输入jmap -
常用选项(属性):
也可以在服务中查看:
例如:jmap -heap
参数说明:
Heap Configuration: #堆配置情况
MinHeapFreeRatio #堆最小使用比例
MaxHeapFreeRatio #堆最大使用比例
MaxHeapSize #堆最大空间
NewSize #新生代初始化大小
MaxNewSize #新生代可使用最大容量大小
OldSize #老生代大小
NewRatio #新生代比例
SurvivorRatio #新生代与suvivor的占比
MetaspaceSize #元数据空间初始大小
CompressedClassSpaceSize #类指针压缩空间大小, 默认为1G
MaxMetaspaceSize #元数据空间的最大值, 超过此值就会触发 GC溢出( JVM会动态地改变此值)
G1HeapRegionSize #区块的大小
Heap Usage:
G1 Heap:
regions # G1区块初始化大小
capacity #G1区块最大可使用大小
used #G1区块已使用内存
free #G1区块空闲内存
18.137190118432045% used #G1区块使用比例
G1 Young Generation: #新生代
Eden Space: #Eden区空间
regions = 670
capacity = 2699034624 (2574.0MB)
used = 1405091840 (1340.0MB)
free = 1293942784 (1234.0MB)
52.05905205905206% used
Survivor Space: #Survivor区
regions = 3
capacity = 6291456 (6.0MB)
used = 6291456 (6.0MB)
free = 0 (0.0MB)
100.0% used
G1 Old Generation: #老生代
regions = 72
capacity = 1589641216 (1516.0MB)
used = 146589472 (139.79861450195312MB)
free = 1443051744 (1376.2013854980469MB)
9.221544492213267% used
JSTAT的使用
JSTAT是一个用于监视和收集Java虚拟机(JVM)统计数据的命令行工具。它提供了多个选项和属性,用于显示不同方面的JVM统计信息。
以下是JSTAT的使用方法和常用属性的解析:
使用方法:
输入jstat -
其中
常用选项(属性):
也可以在Linux中查看具体的选项:
例如:jstat -gcutil 23397 1000 15 -- 每秒中打印一次,打印15次
也可以换成如下写法:
通过查看 新生代、老年代以及GC的次数、时间、调整服务启动参数的设置
参数解析:
通过分析这些参数信息,可以了解垃圾回收器的使用情况、堆内存的使用情况和变化趋势等,帮助识别内存问题并进行性能调优。
例如:jstat -gccause 23397 1s 10 -- 查看GC的原因
JSTACK的使用
jstack是一个用于生成Java线程转储快照的命令行工具,它可以帮助分析和诊断Java应用程序中的线程问题。
使用方法:
输入jstack [-m]
常用选项(属性):
输出解析:
jstack输出的内容包含了当前Java进程中所有线程的堆栈跟踪信息。每个线程的堆栈跟踪以线程ID开始,并按照调用层次结构显示方法调用序列。
以下是一些常见的线程状态和属性的解析:
通过分析线程转储快照,可以了解Java应用程序中各个线程的状态、堆栈跟踪信息以及可能存在的死锁或性能问题。这对于诊断和解决线程相关的问题非常有帮助。
请注意,jstack命令需要与目标Java进程具有相同的用户权限才能执行成功。另外,建议在生产环境中谨慎使用该命令,以避免对应用程序性能产生不利影响。
例如: jstack -l 23397
JCMD的使用
使用帮助文档:
使用 jcmd 获取服务进程
使用 jcmd
例如: jcmd 23397 GC.heap_info
例如: jcmd 23397 Thread.print
总之,jcmd是一个功能强大的工具,可以帮助开发人员和运维人员对Java应用程序进行诊断、监控和管理,从而提高应用程序的可靠性和性能。