jvm(11) -- 虚拟机调试工具(下)

简介: jvm(11) -- 虚拟机调试工具(下)

示例三:-flag [+|-]name


命令:jinfo -flag [+|-]name pid

描述:开启或者关闭对应名称的参数


使用 jinfo 可以在不重启虚拟机的情况下,可以动态的修改 jvm 的参数。尤其在线上的环境特别有用。


使用如下:


1dc618a0ed9580ce8bfa6facb208c08f.png


示例四:-flag name=value


命令:jinfo -flag name=value pid

描述:修改指定参数的值。


同示例三,但示例三主要是针对 boolean 值的参数设置的。

如果是设置 value值,则需要使用 name=value 的形式。


使用如下:


5d4c6812c8535adbb050f4ddf2e1bce8.png


注意事项 :


jinfo虽然可以在java程序运行时动态地修改虚拟机参数,但并不是所有的参数都支持动态修改


示例五: -flags


命令:jinfo -flags pid

描述:输出全部的参数


46a9d80a6e05e4e3b19d57a0ee70bcdf.png


示例六:-sysprops


命令:jinfo -sysprops pid

描述:输出当前 jvm 进行的全部的系统属性


66ba272a0bfc97be54a5fa679e3d5482.png


4.jmap


1dc618a0ed9580ce8bfa6facb208c08f.png


官网地址:<https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jmap.html>


概述


命令jmap是一个多功能的命令。它可以生成 java 程序的 dump 文件, 也可以查看堆内对象示例的统计信息、查看 ClassLoader 的信息以及 finalizer 队列。


jmap 用法


5d4c6812c8535adbb050f4ddf2e1bce8.png


参数:


option: 选项参数。

pid: 需要打印配置信息的进程ID。

executable: 产生核心dump的Java可执行文件。

core: 需要打印配置信息的核心文件。

server-id 可选的唯一id,如果相同的远程主机上运行了多台调试服务器,用此选项参数标识服务器。

remote server IP or hostname 远程调试服务器的IP地址或主机名。

option


no option: 查看进程的内存映像信息,类似 Solaris pmap 命令。

heap: 显示Java堆详细信息

histo[:live]: 显示堆中对象的统计信息

**clstats:**打印类加载器信息

finalizerinfo: 显示在F-Queue队列等待Finalizer线程执行finalizer方法的对象

**dump::**生成堆转储快照

F: 当-dump没有响应时,使用-dump或者-histo参数. 在这个模式下,live子参数无效.

**help:**打印帮助信息

**J:**指定传递给运行jmap的JVM的参数


示例一:no option


命令:jmap pid

描述:查看进程的内存映像信息,类似 Solaris pmap 命令。


使用不带选项参数的jmap打印共享对象映射,将会打印目标虚拟机中加载的每个共享对象的起始地址、映射大小以及共享对象文件的路径全称。这与Solaris的pmap工具比较相似。


1dc618a0ed9580ce8bfa6facb208c08f.png


示例二:heap


命令:jmap -heap pid

描述:显示Java堆详细信息


打印一个堆的摘要信息,包括使用的GC算法、堆配置信息和各内存区域内存使用信息


C:\Users\jjs>jmap -heap 5932
Attaching to process ID 5932, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 25.91-b15
using thread-local object allocation.
Parallel GC with 4 thread(s)
Heap Configuration:
   MinHeapFreeRatio         = 0
   MaxHeapFreeRatio         = 100
   MaxHeapSize              = 1073741824 (1024.0MB)
   NewSize                  = 42991616 (41.0MB)
   MaxNewSize               = 357564416 (341.0MB)
   OldSize                  = 87031808 (83.0MB)
   NewRatio                 = 2
   SurvivorRatio            = 8
   MetaspaceSize            = 21807104 (20.796875MB)
   CompressedClassSpaceSize = 1073741824 (1024.0MB)
   MaxMetaspaceSize         = 17592186044415 MB
   G1HeapRegionSize         = 0 (0.0MB)
Heap Usage:
PS Young Generation
Eden Space:
   capacity = 60293120 (57.5MB)
   used     = 44166744 (42.120689392089844MB)
   free     = 16126376 (15.379310607910156MB)
   73.25337285580842% used
From Space:
   capacity = 5242880 (5.0MB)
   used     = 0 (0.0MB)
   free     = 5242880 (5.0MB)
   0.0% used
To Space:
   capacity = 14680064 (14.0MB)
   used     = 0 (0.0MB)
   free     = 14680064 (14.0MB)
   0.0% used
PS Old Generation
   capacity = 120061952 (114.5MB)
   used     = 19805592 (18.888084411621094MB)
   free     = 100256360 (95.6119155883789MB)
   16.496143590935453% used
20342 interned Strings occupying 1863208 bytes.


示例三:histo[:live]


命令:jmap -histo:live pid

描述:显示堆中对象的统计信息


其中包括每个Java类、对象数量、内存大小(单位:字节)、完全限定的类名。打印的虚拟机内部的类名称将会带有一个’*’前缀。如果指定了live子选项,则只计算活动的对象。


5d4c6812c8535adbb050f4ddf2e1bce8.png


示例四:clstats


命令:jmap -clstats pid

描述:打印类加载器信息


-clstats是-permstat的替代方案,在JDK8之前,-permstat用来打印类加载器的数据

打印Java堆内存的永久保存区域的类加载器的智能统计信息。对于每个类加载器而言,它的名称、活跃度、地址、父类加载器、它所加载的类的数量和大小都会被打印。此外,包含的字符串数量和大小也会被打印。


46a9d80a6e05e4e3b19d57a0ee70bcdf.png


示例五:finalizerinfo


命令:jmap -finalizerinfo pid

描述:打印等待终结的对象信息


66ba272a0bfc97be54a5fa679e3d5482.png


Number of objects pending for finalization: 0 说明当前F-QUEUE队列中并没有等待Fializer线程执行final


示例六:dump:


命令:jmap -dump:format=b,file=heapdump.phrof pid

描述:生成堆转储快照dump文件。


以hprof二进制格式转储Java堆到指定filename的文件中。live子选项是可选的。如果指定了live子选项,堆中只有活动的对象会被转储。想要浏览heap dump,你可以使用jhat(Java堆分析工具)读取生成的文件。


这个命令执行,JVM会将整个heap的信息dump写入到一个文件,heap如果比较大的话,就会导致这个过程比较耗时,并且执行的过程中为了保证dump的信息是可靠的,所以会暂停应用, 线上系统慎用。


1dc618a0ed9580ce8bfa6facb208c08f.png


5.jhat


官网:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jhat.html


该jhat命令解析Java堆转储文件并启动Web服务器。该jhat命令使您可以使用自己喜欢的Web浏览器浏览堆转储。该jhat命令支持预先设计的查询,例如显示已知类的所有实例MyClass以及对象查询语言(OQL)。OQL与SQL类似,除了查询堆转储。可从jhat命令显示的OQL帮助页面获得有关OQL的帮助。使用默认端口,可以从http//localhost:7000/oqlhelp /获得OQL帮助。


案例:


1.导出dump信息到a.bin文件

5d4c6812c8535adbb050f4ddf2e1bce8.png

2.启动jhat进行分析文件

46a9d80a6e05e4e3b19d57a0ee70bcdf.png


3.浏览器查看


66ba272a0bfc97be54a5fa679e3d5482.png


Heap Histogram

5d4c6812c8535adbb050f4ddf2e1bce8.png

OQL

46a9d80a6e05e4e3b19d57a0ee70bcdf.png


6.jstack


官方地址:


https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jstack.html


jstack是jdk自带的线程堆栈分析工具,使用该命令可以查看或导出 Java 应用程序中线程堆栈信息。


例子:


高手是如何用jstack找到异常代码的

jvm 性能调优工具之 jstack(用法+死锁案例)

演示:


方式1:直接查看堆栈信息


1dc618a0ed9580ce8bfa6facb208c08f.png


方式2:


java用thread的api有个方法:Thread.getAllStackTraces().也可以查看堆栈信息。

5d4c6812c8535adbb050f4ddf2e1bce8.png

打印结果如下:

46a9d80a6e05e4e3b19d57a0ee70bcdf.png


二、可视化工具


1.jconsole


该jconsole命令启动图形控制台工具,使您可以监视和管理本地或远程计算机上的Java应用程序和虚拟机。


官网地址:<https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jconsole.html>

1dc618a0ed9580ce8bfa6facb208c08f.png


①内存监控


写个demo测试下:


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


cmd中输入jconsole

5d4c6812c8535adbb050f4ddf2e1bce8.png


查看堆和线程等信息的变化:


46a9d80a6e05e4e3b19d57a0ee70bcdf.png66ba272a0bfc97be54a5fa679e3d5482.png88b9988b40447cb37c7e3c492d49867f.png


②线程监控


public class Main {
    public static void main(String[] args) {
        //创建一个输入流,让程序卡在这里
        Scanner sc = new Scanner(System.in);
        sc.next();
        new Thread(new Runnable() {
            @Override
            public void run() {
                while(true){
                }
            }
        },"while true线程").start();
        sc.next();
        testWait(new Object());
    }
    private static void testWait(Object obj) {
        System.out.println("----testWait-------");
       new Thread(new Runnable() {
           @Override
           public void run() {
               synchronized (obj){
                   try {
                       obj.wait();
                   }catch (InterruptedException e){
                       e.printStackTrace();
                   }
               }
           }
       },"testWait 线程").start();
    }
}

1dc618a0ed9580ce8bfa6facb208c08f.png


监控输入流的线程


5d4c6812c8535adbb050f4ddf2e1bce8.png


监控runnable线程

46a9d80a6e05e4e3b19d57a0ee70bcdf.png


监控wait线程


66ba272a0bfc97be54a5fa679e3d5482.png88b9988b40447cb37c7e3c492d49867f.png


③线程死锁监控


测试代码


public class DeadLock implements Runnable {
    private Object obj1;
    private Object obj2;
    public DeadLock(Object obj1, Object obj2) {
        this.obj1 = obj1;
        this.obj2 = obj2;
    }
    @Override
    public void run() {
        synchronized (obj1){
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            synchronized (obj2){
                System.out.println("Hello");
            }
        }
    }
}


public class Main {
    public static void main(String[] args) {
        Object obj1 = new Object();
        Object obj2 = new Object();
        new Thread(new DeadLock(obj1, obj2)).start();
        new Thread(new DeadLock(obj2, obj1)).start();
    }
}


使用jconsole查看

1dc618a0ed9580ce8bfa6facb208c08f.png


点击检测死锁


5d4c6812c8535adbb050f4ddf2e1bce8.png

46a9d80a6e05e4e3b19d57a0ee70bcdf.png



2.visualVM


VisualVM是一个以监控、显示本地或者远程服务器 JVM工作情况,进行性能调优的工具。借助VisualVM,我们可以实现对JVM内存各个子池、CPU、垃圾收集器等方面进行监控,从而发现程序代码中潜在的泄露点和配置问题。


VisualVM是一个Java编写的绿色软件,属于开源范畴。VisualVM是使用插件Plugin的方式提供功能,默认提供了一些基本检测功能。如果需要进行拓展,可以使用下载插件的功能进行。


下载地址: https://visualvm.github.io/index.html


插件下载地址:https://visualvm.github.io/pluginscenters.html


①安装:


安装完毕,打开exe

1dc618a0ed9580ce8bfa6facb208c08f.png


如果打开了idea或者eclipse,可以在左侧菜单栏看到:

5d4c6812c8535adbb050f4ddf2e1bce8.png


可以看到,各种idea的各种信息


46a9d80a6e05e4e3b19d57a0ee70bcdf.png


②插件下载


可以用这个地址:


插件下载地址:<https://visualvm.github.io/pluginscenters.html


也可以:


在线安装:


1dc618a0ed9580ce8bfa6facb208c08f.png

5d4c6812c8535adbb050f4ddf2e1bce8.png



相关文章
|
2月前
|
监控 算法 Java
Java虚拟机(JVM)的垃圾回收机制深度解析####
本文深入探讨了Java虚拟机(JVM)的垃圾回收机制,旨在揭示其背后的工作原理与优化策略。我们将从垃圾回收的基本概念入手,逐步剖析标记-清除、复制算法、标记-整理等主流垃圾回收算法的原理与实现细节。通过对比不同算法的优缺点及适用场景,为开发者提供优化Java应用性能与内存管理的实践指南。 ####
|
1月前
|
监控 算法 Java
Java虚拟机(JVM)垃圾回收机制深度剖析与优化策略####
本文作为一篇技术性文章,深入探讨了Java虚拟机(JVM)中垃圾回收的工作原理,详细分析了标记-清除、复制算法、标记-压缩及分代收集等主流垃圾回收算法的特点和适用场景。通过实际案例,展示了不同GC(Garbage Collector)算法在应用中的表现差异,并针对大型应用提出了一系列优化策略,包括选择合适的GC算法、调整堆内存大小、并行与并发GC调优等,旨在帮助开发者更好地理解和优化Java应用的性能。 ####
42 0
|
1月前
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
1月前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
2月前
|
机器学习/深度学习 监控 算法
Java虚拟机(JVM)的垃圾回收机制深度剖析####
本文深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法、性能调优策略及未来趋势。通过实例解析,为开发者提供优化Java应用性能的思路与方法。 ####
57 1
|
2月前
|
Ubuntu 网络安全 虚拟化
VMware虚拟机ping不通原因排查及分析
下面以 VMware 虚拟机为例进行介绍。
1178 3
|
2月前
|
存储 SQL 数据库
虚拟化数据恢复—Vmware虚拟机误还原快照的数据恢复案例
虚拟化数据恢复环境: 一台虚拟机从物理机迁移到ESXI虚拟化平台,迁移完成后做了一个快照。虚拟机上运行了一个SQL Server数据库,记录了数年的数据。 ESXI虚拟化平台上有数十台虚拟机,EXSI虚拟化平台连接了一台EVA存储,所有的虚拟机都存放在EVA存储上。 虚拟化故障: 工组人员误操作将数年前迁移完成后做的快照还原了,也就意味着虚拟机状态还原到数年前,近几年数据都被删除了。 还原快照相当于删除数据,意味着部分存储空间会被释放。为了不让这部分释放的空间被重用,需要将连接到这台存储的所有虚拟机都关掉,需要将不能长时间宕机的虚拟机迁移到别的EXSI虚拟化平台上。
116 50
|
3月前
|
安全 虚拟化 数据中心
Xshell 连接 VMware虚拟机操作 截图和使用
Xshell 连接 VMware虚拟机操作 截图和使用
88 4
|
3月前
|
Linux 虚拟化
vmware虚拟机安装2024(超详细)
vmware虚拟机安装2024(超详细)
435 6
|
3月前
|
虚拟化 网络虚拟化 网络架构
虚拟机 VMware Workstation 16 PRO 的网络配置
虚拟机 VMware Workstation 16 PRO 的网络配置
102 2