Java命令行监控工具(jmap,jstack,jstat,jinfo,jps)

简介: 项目部署上线之后,线上项目是不能轻易修改的,定位问题的难度也会变大。因此监控是非常重要的一个环节,有了监控,我们才能更好的定位系统中的问题,从而排查。监控的工具有很多种, 但是java自带的命令行监控工具,是必须要掌握的。

项目部署上线之后,线上项目是不能轻易修改的,定位问题的难度也会变大。因此监控是非常重要的一个环节,有了监控,我们才能更好的定位系统中的问题,从而排查。监控的工具有很多种, 但是java自带的命令行监控工具,是必须要掌握的。

jps

查看系统中jvm进程, 其它的命令通常先使用jps查看进程号,然后在根据线程号获取jvm进程信息


img_422010aa417474181c49b834d3dfd9b1.png
image.png

jps -m 查看jvm进程并且带有参数查看
jps -v 查看传递到jvm的参数

官方jps解释:https://docs.oracle.com/javase/7/docs/technotes/tools/share/jps.html

jstat

显示JVM的性能统计信息,
常见用法:jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
例如:查看JIT编译信息,GC信息和JVM中的class信息。


img_44a5f3adf672694fbb0b99b512852c39.png
image.png

解释下-gc选项中列的含义:-gc查看垃圾收集器中的信息, 主要包含jvm的运行时数据区统计。
后缀为C的代表当前区的容量,后缀为U的代表已经使用了多少容量,后缀为T的代表耗时

S0C 存活区0的容量(KB)
S1C 存活区1的容量(KB)
S0U 存活区0使用的空间 (KB).
S1U 存活区1的利用空间 (KB).
EC Eden区的容量(KB).
EU Eden区利用的容量(KB).
OC 老年代容量(KB).
OU 老年代使用容量(KB).
PC 当前永久带的容量(KB).
PU 永久带使用容量(KB).
YGC 发生了多少次Young GC
YGCT Young GC的时间
FGC Full GC的次数
FGCT Full GC的收集时间
GCT 总共的GC时间.

官方jstat解释:https://docs.oracle.com/javase/7/docs/technotes/tools/share/jstat.html

jstack

查看线程堆栈信息,在发生死锁的时候可以利用这个命令查找死锁或者在发生死循环的时候利用此命令排查。

jstack vmpid 会打印线程的堆栈信息。通过堆栈可以查看具体线程正在执行那些代码,厦门演示两个使用jstack排查死锁与死循环的命令。

死锁代码:

public class DeadLock {

    private static Object o1 = new Object();
    private static Object o2 = new Object();
    private static CountDownLatch countDownLatch = new CountDownLatch(2);

    public static void main(String[] args) throws InterruptedException {
        new Thread(){
            @Override
            public void run() {
                synchronized (o1){
                    try {
                        Thread.sleep(100);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("线程1 获得锁1");
                    synchronized (o2){
                        System.out.println("线程1 获得锁2");
                        countDownLatch.countDown();
                    }
                }
            }
        }.start();

        new Thread(){
            @Override
            public void run() {
                synchronized (o2){
                    try {
                        Thread.sleep(100);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("线程2 获得锁2");
                    synchronized (o1){
                        System.out.println("线程2 获得锁1");
                        countDownLatch.countDown();
                    }
                }
            }
        }.start();

        countDownLatch.await();
        System.out.println("执行完毕");
        
    }

}

死锁之后:
可以看到jstack已经帮我们找到了死锁。


img_601d95b51c12bf1903baf74eb1e3f88b.png
image.png

img_6c7144f0ff0b8d2a96dcc5f6cee74fb3.png
image.png

死循环需要配合Top命令一起使用,死循环会导致CPU不断的飙升,这时候使用top命令,查看cpu占用率较高的命令:

img_c13bc62f54ddd0df447cd0fb5e71c293.png
image.png

使用top -H -p 24278 查看进程中具体是那一条线程的CPU利用率高


img_d994e2b41760a0a2ba1b839a925a4048.png
image.png

可以看到是24279的线程,在top中使用的是10进制,在jstack中打印的线程是16进制,因此做一次转换。
24279 => 5ed7
然后查看线程:


img_bb066e66af41580d9549de7da36fd8ad.png
image.png

然后我们可以知道具体那一行的指令在一直运行。

jstack官方文档解释

jinfo查看JVM启动时候设置的参数值

jinfo可以查看当前JVM线程配置的系统属性,以及运行时设置的参数值。

直接使用jinfo

  1. 前半段是系统的属性


    img_99159753650a39b7321d235ce6e8bf32.png
    image.png
  1. 后半段是jvm的参数


    img_cdbdfa19dcc71045c5f2699930b14572.png
    image.png

我们也可以直接使用jinfo查看具体的某个参数值:


img_d689ebc16a8d1f5ea4cb46d7792d2256.png
image.png

jinfo官方解释

jmap分析堆

在发生OME的时候,会用jmap分析堆中具体是什么问题,才能更好的解决问题。jmap一般和mat配合使用。

一般在java开发的项目启动时候,最好加上下面命令,在内存溢出的时候可以通过日志查看信息。
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/java/dump

当然在项目运行的时候也可以使用jmap -heap jvmpid查看对象内存的映射。

演示内存溢出

堆内存溢出代码

public class DealCycle {
    public static LinkedList<Integer> linkedList = new LinkedList<>();
    public static void main(String[] args) {
        int i = 0;
        while (true){
            linkedList.add(i);
        }
    }
}

运行:


img_26ea53157c8841cc758cadd64c23f0a9.png
image.png

大家可以去网站上下载java mat的二进制压缩包,学习一下

在线分析hprof文件:
http://heaphero.io/

img_6f69ed108c0de6a0175b15f5f6983d1b.png
image.png

img_4a9a85db9830c23095deda813cb4e97d.png
image.png

如果每次都等到内存溢出才导出文件时间就有些晚了,可以使用jmap直接导出

img_59ad13a1a67021cba38ae9a5c97a5dfd.png
image.png

jmap官方解释

最后

这篇文章主要介绍了java自带的命令行工具,通过这些命令行工具,我们可以很好的得知当前jvm的运行状态。

相关文章
|
3月前
|
运维 监控 Java
使用jps命令查看Java进程
`jps`是Java开发者和系统管理员的得力助手,它简化了Java进程监控的过程,使得快速检查应用运行状态变得轻而易举。通过合理利用其提供的参数,可以高效地进行故障排查、性能监控及日常管理任务,确保Java应用稳定运行。
169 2
|
5月前
|
小程序 JavaScript Java
【Java】服务CPU占用率100%,教你用jstack排查定位
本文详细讲解如何使用jstack排查定位CPU高占用问题。首先介绍jstack的基本概念:它是诊断Java应用程序线程问题的工具,能生成线程堆栈快照,帮助找出程序中的瓶颈。接着,文章通过具体步骤演示如何使用`top`命令找到高CPU占用的Java进程及线程,再结合`jstack`命令获取堆栈信息并进行分析,最终定位问题代码。
522 1
【Java】服务CPU占用率100%,教你用jstack排查定位
|
6月前
|
Java
Jstack 查看线程状态及定位占用 cpu 较高的 java 线程
Jstack 查看线程状态及定位占用 cpu 较高的 java 线程
756 2
|
6月前
|
Java 运维
开发与运维命令问题之使用jstack命令查看Java进程的线程栈如何解决
开发与运维命令问题之使用jstack命令查看Java进程的线程栈如何解决
75 2
|
6月前
|
监控 Java 开发者
Java面试题:如何使用JVM工具(如jconsole, jstack, jmap)来分析内存使用情况?
Java面试题:如何使用JVM工具(如jconsole, jstack, jmap)来分析内存使用情况?
248 2
|
6月前
|
NoSQL Java 数据库
数据库问题之使用jmap命令获取Java堆信息如何解决
数据库问题之使用jmap命令获取Java堆信息如何解决
42 0
|
7月前
|
Java 编译器 Windows
用命令行运行Java代码
用命令行运行Java代码
44 0
|
8月前
|
Java
探秘jstack:解决Java应用线程问题的利器
探秘jstack:解决Java应用线程问题的利器
261 1
探秘jstack:解决Java应用线程问题的利器
|
Java
Java打包常用命令行参数
Java打包常用命令行参数
80 0
|
8月前
|
Java Maven
Maven【2】( Web 工程依赖 Java 工程)(命令行操作)
Maven【2】( Web 工程依赖 Java 工程)(命令行操作)
82 0