栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JDK监控和诊断工具——jconsole

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JDK监控和诊断工具——jconsole

文章目录
    • 1.查看
    • 2.各区域详解
      • 2.1.内存
        • 2.1.1.观察内存的波动
      • 2.2.线程
        • 2.2.1.观察线程的波动
      • 2.3.类
      • 2.4.VM概要

1.查看

jconsole命令,可以启动图形控制台来监视和管理 Java 应用程序。需要有桌面环境,Linux没桌面的服务器,不能用。

打开cmd或powershell输入jconsole -h,就会弹出来jconsole的帮助命令界面。

(base) PS G:Projecthighway-resources>jconsole -h

这些都是中文,不过多解释了。既然是图像界面,用操作来讲解。

在cmd或powershell输入jconsole,会打开JConsole的图像界面。

我们提前运行一个Java程序,以方便我们观察

import java.util.concurrent.TimeUnit;


public class TestJConsole {
    public static void main(String[] args) {
        System.out.println("hello world");
        try {
            Thread.currentThread().setName("Test jconsole");
            //等待十分钟,方便使用jconsole命令
            TimeUnit.MINUTES.sleep(10);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
    }
}

选不安全的连接。这个主要是因为没用https,这个不影响。连接后进到下面的概要界面。

概览,没什么好解释的,显示的是一个统计汇总后的结果。可以选择后面的内存、线程、类、VM概要、MBean来查看各项的详细内容,主要是前四个。

2.各区域详解 2.1.内存

内存:就是查看JVM运行时,占用的内存情况。这里可选各种内存的使用情况。如果不了解JVM运行时内存划分的话,可以参考我这边文章面试必备——图文剖析JVM的运行时数据区_编程还未的博客-CSDN博客

2.1.1.观察内存的波动

我们用一个demo,模拟一下频繁使用时,内存的情况。

启动jconsole的时候,可以用jconsole -interval=1,每秒刷新一次。

public class TestJConsole1 {
    public static void main(String[] args) throws InterruptedException {
        //循环一万次,创建数组
        for (int i = 0; i < 10000; i++) {
            int[] a = new int[1024];
            //暂停100毫秒,不然一万次循环太快,没等打开工具就执行完了
            TimeUnit.MILLISECONDS.sleep(100);
        }
    }
}

2.2.线程

线程这块,就是观察线程的数量。

上图红框位置是当前进程下的线程列表,点击选择后,右侧是线程的详细信息,可以进行线程的堆栈跟踪。

2.2.1.观察线程的波动

我们用一个demo,模拟一下频繁使用时,线程的情况。

启动jconsole的时候,可以用jconsole -interval=1,每秒刷新一次。这个观察一下就可以把程序关掉,让他自己运行完,有可能把CPU跑崩掉。

import java.util.concurrent.TimeUnit;


public class TestJConsole2 {
    public static void main(String[] args) throws InterruptedException {
        //循环一万次,创建线程
        for (int i = 0; i < 10000; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    try {
                        TimeUnit.SECONDS.sleep(60);
                        System.out.println("线程创建");
                    } catch (InterruptedException e) {
                        throw new RuntimeException(e);
                    }
                }
            }).start();
            TimeUnit.MILLISECONDS.sleep(100);
        }
        TimeUnit.SECONDS.sleep(60);
    }
}

2.3.类

类这个就是加载的类。这个没什么好说的。

2.4.VM概要

这个是JVM相关的信息,版本信息,配置参数等。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/826987.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号