JVM基础到实战08-图形化分析工具jconsole

jconsole是JDK自带的一个图形化的jvm分析工具

我们启动一个项目,直接在cmd窗口下输入jconsole,发现会跳出一个jconsole的程序界面

可以看到,他直接提供了可选择的本地进程,以及需要输入账号密码的远程进程,而不是像前面使用jmap,和jstack分析的时候,需要我们先用jps列出进程pid,我们选择本地应用 pid2976

连接成功后,进入jconsole的主页面,里边展示当前进程的概况,*如果有提示,请选择不安全的连接*

内存:

线程:

点击检测死锁,会发现,我们项目的死锁线程被检测到了

可以查看vm参数:

二、实战

我们模拟一个内存增长的场景:

①代码

/**
 * @Auther: jorian
 * @Date: 2019/8/14 21:47
 * @Description:内存增长模拟
 */
public class JconsoleMemory {
    public byte[] b1 = new byte[1024*512];
    public static void main(String []args) throws InterruptedException{
      System.out.println("main thread start");
      Thread.sleep(10000);
      allocate(10000);
    }
    public static void allocate(int n){
        List<JconsoleMemory> jconsoleMemoryList = new ArrayList<>();
        for(int i = 0; i < n; i++){
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            jconsoleMemoryList.add(new JconsoleMemory());
        }
    }

}

②启动项目等2秒,然后启动jconsole,观察内存变化

堆内存:

老年代:

eden区发生gc,所以内存先增大,到一定程度会被回收变小,大量的内存被复制到老年代

 Metaspace(元数据区),1.8之后的老年代

当类加载完毕就几乎不在发生变化

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值