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/713752/

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

(0)

大家都在看

  • k8s 新版本 部署 Ingress-nginx controller

    k8s 新版本 部署 Ingress-nginx controller 本篇主要记录一下 k8s 新版本 1.23.5 中如何搭建 ingress controller 以及里面的…

    技术杂谈 2023年7月11日
    057
  • 网易云音乐解锁灰色歌曲教程

    前言 这个项目地址是Github上的一个大佬开发的,已经开源,项目地址:https://github.com/meng-chuan/Unlock-netease-cloud-mus…

    技术杂谈 2023年6月21日
    0105
  • Vue前端访问控制方案

    1、前端访问控制的常规处理方法 前端访问控制,一般针对界面元素dom element进行可见属性或enable属性进行控制,有权限的,相关元素可见或使能;没权限的,相关元素不可见或…

    技术杂谈 2023年6月21日
    072
  • 会话技术 cookie 和 Session(1)

    CookieCookie 属于客户端会话技术,它是服务器发送给浏览器的小段文本信息,存储在客户端浏览器的内存中或硬盘上。当浏览器保存了Cookie 后,每次访问服务器,都会在HTT…

    技术杂谈 2023年6月21日
    0128
  • python 对潜在客户数据集 进行数据分析

    大家好,我是小寒。 今天给大家带来一篇 探索性数据分析(EDA) 案例分享。如果觉得不错,可以多多分享。 什么是探索性数据分析 探索性数据分析 (EDA) 是任何数据科学或数据分析…

    技术杂谈 2023年7月25日
    073
  • 线段树建造

    1、由于二叉树的自身特性,对于每个父亲节点的编号 i,他的两个儿子的编号分别是 2i 和 2i+1,所以我们考虑写两个 O(1) 的取儿子函数: inline int ls(int…

    技术杂谈 2023年7月11日
    058
  • java学习之JSP

    JSP:全拼写:java Server pages:java 服务器端页面可以理解为一个特殊的页面:可以定义html代码也可以定义java的代码定义:JSP是简化Servlet编写…

    技术杂谈 2023年6月21日
    075
  • MySQL窗口函数

    窗口函数概念和语法 窗口函数对一组查询行执行类似聚合的操作。然而,聚合操作将查询行分组到单个结果行,而窗口函数为每个查询行产生一个结果: 函数求值发生的行称为当前行 与发生函数求值…

    技术杂谈 2023年7月24日
    067
  • Flink 资源管理详解

    大家好,我是小寒~ 在 Flink 中提交作业到 Flink 集群后, Flink 集群是如何为作业分配资源,以及如何管理集群资源的呢?今天我们就来聊一聊 Flink 资源管理相关…

    技术杂谈 2023年7月24日
    087
  • 内存泄漏过度释放检測

    假设出现exc_bad_access错误,基本上是因为内存泄漏,错误释放。对一个已经释放的对象进行release操作。可是xcode有时候不会告诉你错误在什么地方(Visual S…

    技术杂谈 2023年5月31日
    079
  • 数组的改变和移动

    1.1 数组的改变 数组在内存中是一块连续的内存空间,我们可以直接通过下标进行访问,并进行修改。 在 Java中,对于 List类型来说,我们可以通过 set(idx, eleme…

    技术杂谈 2023年6月21日
    083
  • Map–部分方法

    1.Map.values()方法:获取Map集合中的所有键值对象 获取 Map 集合中的所有键值对象,这些键值对象将存放在另一个集合对象中 2.getOrDefault() 方法 …

    技术杂谈 2023年7月24日
    074
  • Win10系统的DELL平板如何重装WIN10系统

    首先参考”Win10系统的SurfacePro4如何重装系统-1 SurfacePro专用的PE”这篇文章,做一个WIN10平板专用的PE 然后开机按F2可…

    技术杂谈 2023年5月31日
    095
  • 服务治理-布隆过滤器

    布隆过滤器 布隆过滤器(英语:Bloom Filter)是1970年由布隆提出的。它实际上是一个很长的二进制向量和一系列随机映射函数。元素可以添加到集合中,但不能删除(计数布鲁姆过…

    技术杂谈 2023年7月11日
    078
  • tomcat启动控制台和system.out.println输出中文乱码问题

    问题描述:在ideal项目中,使用tomcat启动项目,控制台乱码和在ideal中编写java程序使用system.out.prinln(“中文”)在控制台…

    技术杂谈 2023年5月31日
    066
  • 博客园配置Metaweblog访问令牌

    如何配置Metaweblog访问令牌?如何通过访问令牌登录博客园? 最近博客园升级了 Metaweblog访问令牌 ,发布博客时 使用密码不能发布了; 如何更新呢? 进入后台 设置…

    技术杂谈 2023年5月31日
    0109
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球