JVM诊断命令jcmd介绍

原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处。

简介

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

列出java进程

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

$ jcmd
10732 app.jar
10767 sun.tools.jcmd.JCmd

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

列出jcmd支持的子命令

$ jcmd 10732 help
10732:
The following commands are available:
VM.native_memory
VM.classloader_stats
Thread.print
GC.class_stats
GC.class_histogram
GC.heap_dump
GC.finalizer_info
GC.heap_info
GC.run_finalization
GC.run
VM.uptime
VM.dynlibs
VM.flags
VM.system_properties
VM.command_line
VM.version
help

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

查看java线程栈

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

JVM诊断命令jcmd介绍

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

查看jvm堆情况

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

$ jcmd 0 GC.heap_info
10732:
 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一样查看堆直方图并转储堆内存到文件中,以分析内存不合理的占用问题,如下:

`bash
堆直方图,查看哪些类的对象实例最多
$ jcmd 0 GC.class_histogram
10732:

num #instances #bytes class name

Original: https://www.cnblogs.com/codelogs/p/16535451.html
Author: 扣钉日记
Title: JVM诊断命令jcmd介绍

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/581357/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 1-快速体验 Spring Security 5.7.2 | 权限管理基础

    在前面SpringBoot 2.7.2 的系列文章中,已经创建了几个 computer 相关的接口,这些接口直接通过 Spring Doc 或 POSTMAN 就可以访问。例如: …

    Java 2023年6月16日
    0109
  • java对形参操作能否改变实参

    这个问题其实以前就断断续续的纠结过,这次机缘巧合之下稍微深入的理解了这个问题。 这里的问题是:在主方法里创建了N个一般属性,将这些属性传递给其他方法,当 其他方法改变了传递来的形参…

    Java 2023年6月7日
    067
  • 英语自我介绍

    问候语 个人情况介绍:姓名,年龄,故乡,本科院校和专业,注意本科院校的翻译不要错 本科经历:包括学习成绩,学生工作经历,社会活动,竞赛情况,实习经历,论文阅读情况(没有的话就从寒假…

    Java 2023年6月7日
    050
  • Java8之Optional用法举例

    一、简介 Optional 类是一个可以为null的容器对象。如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象。Optional 是个容器:它可…

    Java 2023年5月29日
    078
  • Java开发学习(九)—-IOC之核心容器

    这里所说的核心容器,大家可以把它简单的理解为 ApplicationContext,前面虽然已经用到过,但是并没有系统的介绍过,接下来咱们从以下几个问题入手来下容器的相关知识: 如…

    Java 2023年5月29日
    075
  • SpringCloud 学习总结

    服务注册中心 Nacos nacos-server-2.1.1\nacos\bin 目录下打开命令行窗口,输入 startup.cmd -m standalone;访问 http:…

    Java 2023年6月15日
    0105
  • 程序员的自我修养一书的学习 页映射

    页映射,弄得不老懂,进程虚拟地址空间 与 磁盘上的目标文件 映射, 进程虚拟地址空间 与 物理内存 映射, 物理内存 与 磁盘上的目标文件 映射, 三方 都互相关联了。 缺页, 进…

    Java 2023年6月13日
    079
  • JVM学习笔记之了解对象存活判断和4种引用【三】

    垃圾收集器在对堆进行回收前,第一件事情就是要确定这些对象之中哪些还”存活”着,哪些已经”死去” 一、对象存活判断 1.1 引用计数算…

    Java 2023年6月5日
    057
  • Ehcache计算Java对象内存大小

    在EHCache中,可以设置maxBytesLocalHeap、maxBytesLocalOffHeap、maxBytesLocalDisk值,以控制Cache占用的内存、磁盘的大…

    Java 2023年5月29日
    078
  • fiddler抓取不了PC端微信小程序的包解决方法

    最近突然遇到微信抓取不到小程序包,之前都是好的,但突然就凉凉了,以下是自己的操作记录。打开小程序,然后打开任务管理器找到小程序的应用, 右键点击小程序,或者Mini Program…

    Java 2023年6月13日
    074
  • java 驼峰字符和下划线字符相互转换工具类

    public static final char UNDERLINE=’_’; public static String camelToUnderline(String param…

    Java 2023年5月29日
    080
  • java poi生成数据透视表

    /** * 导出EXCEL—poi */ @Override public void pivot(HttpServletResponse response) throws Ex…

    Java 2023年6月16日
    096
  • 手把手教你写一个SpringMVC框架

    一、介绍 在日常的 web 开发中,熟悉 java 的同学一定知道,Spring MVC 可以说是目前最流行的框架,之所以如此的流行,原因很简单: 编程简洁、上手简单! 我记得刚开…

    Java 2023年6月9日
    078
  • Java8 提供的函数接口

    参考资料 函数接口 Java 提供的函数接口位于 java.util.function 包下。 接下来介绍主要的函数接口: Function 接口代表一个 接收1个参数并返回1个结…

    Java 2023年6月9日
    059
  • day02-MySQL基础知识

    MySQL基本知识 1.数据库 1.1.创建数据库 语法: CREATE DATABASE [IF NOT EXISTS] db_name [create_specificatio…

    Java 2023年6月15日
    0100
  • spring cache之自定义keys的过期时间

    spring @cacheable注解默认不支持方法级别的缓存失效时间,只能通过配置来配置全局的失效时间 如果需要实现对方法级别的缓存支持失效时间机制,有一种比较简单的方法,spr…

    Java 2023年6月16日
    078
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球