您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > JAVA

JVM诊断命令jcmd介绍

时间:2022-08-01 15:20:58  来源:  作者:扣钉日记

简介

从JDK7开始,jdk提供了一个方便扩展的诊断命令jcmd,用来取代之前比较分散的jdk基础命令,如jps、jstack、jmap、jinfo等,并且jdk添加新的诊断功能,也会通过jcmd提供,所以还是有必要将这个命令熟悉起来的。

列出JAVA进程

jps提供了列出本机java进程的功能,jcmd与之类似,直接输入jcmd即可,如下:

$ jcmd10732 App.jar10767 sun.tools.jcmd.JCmd

可以看到,本机有一个app.jar的java进程。

列出jcmd支持的子命令

$ jcmd 10732 help10732:The following commands are avAIlable:VM.native_memoryVM.classloader_statsThread.printGC.class_statsGC.class_histogramGC.heap_dumpGC.finalizer_infoGC.heap_infoGC.run_finalizationGC.runVM.uptimeVM.dynlibsVM.flagsVM.system_propertiesVM.command_lineVM.versionhelp

如上,可以看到,10732这个java进程支持了不少子命令呢!

查看java线程栈

jcmd可以像jstack一样,打印java线程栈,使用jcmd 0 Thread.print即可,如下:

 

注:jcmd有个默认行为,当传递给jcmd的进程id是0时,jcmd会在本机所有java进程中执行子命令,这样我们就可以少操作一步了。

查看jvm堆情况

jcmd可以快速查看当前堆容量、已使用容量等等关键信息,如下:

$ jcmd 0 GC.heap_info10732: garbage-first heap   total 204800K, used 44778K [0x00000006f9a00000, 0x00000006f9b00640, 0x00000007c0000000)  region size 1024K, 44 young (45056K), 5 survivors (5120K) Metaspace       used 16876K, capacity 18012K, committed 18304K, reserved 1064960K  class space    used 2101K, capacity 2330K, committed 2432K, reserved 1048576K

也可以像jmap一样查看堆直方图并转储堆内存到文件中,以分析内存不合理的占用问题,如下:

# 堆直方图,查看哪些类的对象实例最多$ jcmd 0 GC.class_histogram 10732: num     #instances         #bytes  class name----------------------------------------------   1:         12659        1142376  [C   2:          3649         403376  java.lang.Class   3:         12644         303456  java.lang.String   4:          9020         288640  java.util.concurrent.ConcurrentHashMap$Node   5:          1378         280376  [B   6:          2241         183608  [I   7:          3351         164296  [Ljava.lang.Object;   8:          1554         133496  [Ljava.util.HashMap$Node;   9:          1192         104896  java.lang.reflect.Method  10:            77         104016  [Ljava.util.concurrent.ConcurrentHashMap$Node;  11:          6307         100912  java.lang.Object  12:          2517         100680  java.util.LinkedHashMap$Entry  13:          3071          98272  java.util.HashMap$Node  14:          1148          55104  java.util.HashMap  15:          1962          46856  [Ljava.lang.Class;  16:           782          43792  java.util.LinkedHashMap# 导出堆内存文件$ jcmd 0 GC.heap_dump /home/work/heap.hprof11377:Heap dump file created

查看jvm属性等

使用jinfo可以查看jvm属性与参数,jcmd同样也可以做到,如下:

# 查看jvm参数$ jcmd 0 VM.flags11377:-XX:CICompilerCount=4 -XX:ConcGCThreads=2 -XX:G1HeapRegionSize=1048576 -XX:InitialHeapSize=209715200 -XX:MarkStackSize=4194304 -XX:MaxHeapSize=3328180224 -XX:MaxNewSize=1996488704 -XX:MinHeapDeltaBytes=1048576 -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseG1GC# 查看jvm属性$ jcmd 0 VM.system_properties11377:#Sat Jul 30 16:50:33 CST 2022java.runtime.name=OpenJDK Runtime Environmentjava.protocol.handler.pkgs=org.springframework.boot.loadersun.boot.library.path=/opt/jdk8u212-b03/jre/lib/amd64java.vm.version=25.212-b03java.vm.vendor=AdoptOpenJDKjava.vendor.url=http://java.oracle.com/path.separator=:java.vm.name=OpenJDK 64-Bit Server VM

查看堆外内存分配情况

为了提升性能,很多基础框架使用了堆外内存,而jcmd可以检查堆外内存的使用情况,如下:

$ jcmd 0 VM.native_memory11817:Native Memory Tracking:Total: reserved=4813774KB, committed=357358KB-                 Java Heap (reserved=3250176KB, committed=204800KB)                            (mmap: reserved=3250176KB, committed=204800KB)-                     Class (reserved=1065417KB, committed=17225KB)                            (classes #3070)                            (malloc=457KB #4487)                            (mmap: reserved=1064960KB, committed=16768KB)-                    Thread (reserved=33955KB, committed=33955KB)                            (thread #34)                            (stack: reserved=33816KB, committed=33816KB)                            (malloc=100KB #177)                            (arena=39KB #62)-                      Code (reserved=250612KB, committed=7124KB)                            (malloc=1012KB #2197)                            (mmap: reserved=249600KB, committed=6112KB)-                  ...-                    Symbol (reserved=4471KB, committed=4471KB)                            (malloc=3376KB #25096)                            (arena=1095KB #1)-               Arena Chunk (reserved=23038KB, committed=23038KB)                            (malloc=23038KB)-                   Unknown (reserved=6348KB, committed=0KB)                            (mmap: reserved=6348KB, committed=0KB)

如上,能够看到jvm原生内存各个段的分配情况。

注:需要添加jvm参数-XX:NativeMemoryTracking=summary才能使用上述功能。

jvm性能数据

通过PerfCounter.print可以查看jvm运行时的一些性能数据,如下:

$ jcmd 0 PerfCounter.print...sun.gc.tlab.alloc=6666220sun.gc.tlab.allocThreads=4sun.gc.tlab.fastWaste=0sun.gc.tlab.fills=102sun.gc.tlab.gcWaste=64976sun.gc.tlab.maxFastWaste=0sun.gc.tlab.maxFills=99...sun.rt._sync_ContendedLockAttempts=81sun.rt._sync_Deflations=42sun.rt._sync_EmptyNotifications=0sun.rt._sync_FailedSpins=0sun.rt._sync_FutileWakeups=15...sun.rt.safepointSyncTime=495700sun.rt.safepointTime=19291400sun.rt.safepoints=13

这里输出内容较多,可以看到jit、gc、tlab、sync、safepoint等的执行情况,当然要完全看懂这些指标,需要对jvm实现比较熟悉才行。

总结

可以看到,jcmd提供的子命令还是挺多的,就不一一介绍了,具体可以通过jcmd 0 help查看。



Tags:jcmd   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
JVM诊断命令jcmd介绍
从JDK7开始,jdk提供了一个方便扩展的诊断命令jcmd,用来取代之前比较分散的jdk基础命令,如jps、jstack、jmap、j...【详细内容】
2022-08-01  Search: jcmd  点击:(559)  评论:(0)  加入收藏
▌简易百科推荐
Java 8 内存管理原理解析及内存故障排查实践
本文介绍Java8虚拟机的内存区域划分、内存垃圾回收工作原理解析、虚拟机内存分配配置,以及各垃圾收集器优缺点及场景应用、实践内存故障场景排查诊断,方便读者面临内存故障时...【详细内容】
2024-03-20  vivo互联网技术    Tags:Java 8   点击:(18)  评论:(0)  加入收藏
如何编写高性能的Java代码
作者 | 波哥审校 | 重楼在当今软件开发领域,编写高性能的Java代码是至关重要的。Java作为一种流行的编程语言,拥有强大的生态系统和丰富的工具链,但是要写出性能优异的Java代码...【详细内容】
2024-03-20    51CTO  Tags:Java代码   点击:(25)  评论:(0)  加入收藏
在Java应用程序中释放峰值性能:配置文件引导优化(PGO)概述
译者 | 李睿审校 | 重楼在Java开发领域,优化应用程序的性能是开发人员的持续追求。配置文件引导优化(Profile-Guided Optimization,PGO)是一种功能强大的技术,能够显著地提高Ja...【详细内容】
2024-03-18    51CTO  Tags:Java   点击:(34)  评论:(0)  加入收藏
Java生产环境下性能监控与调优详解
堆是 JVM 内存中最大的一块内存空间,该内存被所有线程共享,几乎所有对象和数组都被分配到了堆内存中。堆被划分为新生代和老年代,新生代又被进一步划分为 Eden 和 Survivor 区,...【详细内容】
2024-02-04  大雷家吃饭    Tags:Java   点击:(63)  评论:(0)  加入收藏
在项目中如何避免和解决Java内存泄漏问题
在Java中,内存泄漏通常指的是程序中存在一些不再使用的对象或数据结构仍然保持对内存的引用,从而导致这些对象无法被垃圾回收器回收,最终导致内存占用不断增加,进而影响程序的性...【详细内容】
2024-02-01  编程技术汇  今日头条  Tags:Java   点击:(78)  评论:(0)  加入收藏
Java中的缓存技术及其使用场景
Java中的缓存技术是一种优化手段,用于提高应用程序的性能和响应速度。缓存技术通过将计算结果或者经常访问的数据存储在快速访问的存储介质中,以便下次需要时可以更快地获取。...【详细内容】
2024-01-30  编程技术汇    Tags:Java   点击:(78)  评论:(0)  加入收藏
JDK17 与 JDK11 特性差异浅谈
从 JDK11 到 JDK17 ,Java 的发展经历了一系列重要的里程碑。其中最重要的是 JDK17 的发布,这是一个长期支持(LTS)版本,它将获得长期的更新和支持,有助于保持程序的稳定性和可靠性...【详细内容】
2024-01-26  政采云技术  51CTO  Tags:JDK17   点击:(100)  评论:(0)  加入收藏
Java并发编程高阶技术
随着计算机硬件的发展,多核处理器的普及和内存容量的增加,利用多线程实现异步并发成为提升程序性能的重要途径。在Java中,多线程的使用能够更好地发挥硬件资源,提高程序的响应...【详细内容】
2024-01-19  大雷家吃饭    Tags:Java   点击:(111)  评论:(0)  加入收藏
这篇文章彻底让你了解Java与RPA
前段时间更新系统的时候,发现多了一个名为Power Automate的应用,打开了解后发现是一个自动化应用,根据其描述,可以自动执行所有日常任务,说的还是比较夸张,简单用了下,对于office、...【详细内容】
2024-01-17  Java技术指北  微信公众号  Tags:Java   点击:(108)  评论:(0)  加入收藏
Java 在 2023 年仍然流行的 25 个原因
译者 | 刘汪洋审校 | 重楼学习 Java 的过程中,我意识到在 90 年代末 OOP 正值鼎盛时期,Java 作为能够真正实现这些概念的语言显得尤为突出(尽管我此前学过 C++,但相比 Java 影响...【详细内容】
2024-01-10  刘汪洋  51CTO  Tags:Java   点击:(82)  评论:(0)  加入收藏
相关文章
    无相关信息
站内最新
站内热门
站内头条