JVM的一些工具的简要使用

JConsole(可视化工具)

运行
1590876-20190922214932110-1514510585.png

JConsole内存监控

测试代码

import java.util.ArrayList;
import java.util.List;

public class A {
    byte[] b1 = new byte[128*1024];
    public static void main(String[] args) {
        try {
            Thread.sleep(5000);
        }catch(Exception e) {
            
        }
        System.out.println("start...");
        fill(1000);
    }
    private static void fill(int n) {
        List<A> jlist = new ArrayList<A>();
        for(int i=0;i<n;i++) {
            try {
                Thread.sleep(100);
            }catch(Exception e) {
                jlist.add(new A());
            }
        }
    }
}

然后开启jconsole进行连接。

1590876-20190922215501704-532464095.png

连接后执行一次GC后会发现Eden区域直降一次。

1590876-20190922215645288-118880660.png

JConsole线程监控。

测试代码:

import java.util.Scanner;

public class A {
    byte[] b1 = new byte[128*1024];
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        sc.next();
        new Thread(()->{
            while(true) {
                
            }
        },"while true线程").start();  
        new Thread(()->{
            synchronized(A.class) {
                try {
                    Thread.sleep(60000000);
                }catch(InterruptedException e) {
                    e.printStackTrace();
                }   
            }
        },"wait 线程").start();
        
    }
}

这里看到我们有俩个线程。

1590876-20190922221021290-741864609.png

JPS(JVM Process status)

JPS是使用的频率最高的工具,和linux下的ps命令差不多(把J去掉就是一个ps)。

因为我这里开启了一个eclipse,所以运行结果如下所示:

1590876-20190922145048683-762900299.png

如果打开任务管理器,就会发现这里的11612就是我们的pid

1590876-20190922145147044-1380235724.png

因此JPS能够查看:本地虚拟机唯一ID(lvmid local virtual machine id)

测试代码:

import java.util.Scanner;

public class A {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        sc.next();
    }
}

使用jps -l 查看主类

jps -l

1590876-20190922145611901-46407965.png

使用jps -m 查看运行时的参数

jps -m

1590876-20190922145736515-239977321.png

使用jps -v 查看虚拟机参数

jps -v

(上次写的程序还留着参数,所以看起来会有很多)
1590876-20190922145902605-1766238633.png

使用mlv就能查看所有参数。

jps -mlv

Jstat(JVM state)

能看到类加载,内存,垃圾收集。

jstat -gcutil

能查指定id的GC

1590876-20190922150334617-365120270.png

看这个就已经蒙蔽了,所以我们来看一下官方文档。

链接在这

看完之后翻译一下:
|参数|作用|
|----|----|
|S0|Survivor空间0的利用率占当前容量的百分比|
|S1|Survivor空间1的利用率占当前容量的百分比|
|E|Eden区域。。。|
|O|老年代|
等等

jstat -gcutil 8082 1000

每隔1000ms导出一次gc

1590876-20190922203627601-1145880845.png

元空间:本质和永久代类似,都是对JVM规范中方法区的实现。不过元空间与永久代的最大区别在于:元空间并不在虚拟机中,而是使用本地内存。因此,默认情况下,元空间的大小仅受本地内存限制。

jinfo

实时查看和调整虚拟机的各种参数。

jinfo -flag UseG1GC 8082

1590876-20190922204418572-1282199925.png

我们可以看到eclipse使用的就是G1收集器。

还可以动态的去修改JVM参数设置。

jmap

将jvm堆内存dump下来

jmap -dump:format=b,file=C:\Users\GodofOrange\Desktop\a.bin 8082

1590876-20190922213533476-803017306.png

1590876-20190922213811645-979291851.png

显示堆中的统计信息。

jmap -histo 8028 > a.txt

1590876-20190922214033962-304993655.png

jstack

打印线程信息

jstack -F 8028

1590876-20190922214447288-773533691.png

打印栈信息

jstack -m 8028

1590876-20190922214606120-2050252870.png

转载于:https://www.cnblogs.com/godoforange/p/11569594.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值