使用Java工具解决生产故障(一)-jcmd介绍

1.简介

Java开发的应用程序在线上出现生产故障很常见,通常我们会在开发环境模拟此类故障,但偶尔也会遇到无法成功模拟的故障。那么我们就需要在生产环境上进行分析,定位故障产生原因。JDK1.7版本之后新增了一个命令行工具jcmd,那么下面我们就使用jcmd来定位生产故障吧。

2.命令介绍

2.1获取所有的JVM

首先,我们可以通过jcmd获取所有的JVM列表。

>jcmd

直接输入jcmd,就能列出所有运行中的JVM。

7796
8404
7592
1228 sun.tools.jcmd.JCmd
7628 org.jetbrains.idea.maven.server.RemoteMavenServer

通过命令,可以查看到总共有5个JVM正在运行中。

2.2查看jcmd支持的命令
>jcmd <PID> help

7628:
The following commands are available:
VM.native_memory
ManagementAgent.stop
ManagementAgent.start_local
ManagementAgent.start
GC.rotate_log
Thread.print
GC.class_stats
GC.class_histogram
GC.heap_dump
GC.run_finalization
GC.run
VM.uptime
VM.flags
VM.system_properties
VM.command_line
VM.version
help

For more information about a specific command use 'help <command>'.

如果需要对特定的命令进行帮助说明,可以在help之后加上命令名。

>jcmd 7628 help VM.version

7628:
VM.version
Print JVM version info

Impact: Low

Permission: java.util.

Syntax: VM.version

包含了命令的含义、影响、权限、语法等信息。

2.3生成堆dump

很多时候我们需要生成dump,再使用特定工具去详细进行分析(例如VisualVm)。

>jcmd 7628 GC.heap_dump filepath

通过上述命令可以生成相应的堆dump。

GC.heap_dump
Generate a HPROF format dump of the Java heap.

Impact: High: Depends on Java heap size and content. Request a full GC unless the '-all' option is specified.

Permission:             
java.lang.management.ManagementPermission(monitor)

Syntax : GC.heap_dump [options] <filename>

Arguments:
    filename :  Name of the dump file (STRING, no default value)

Options: (options must be specified using the <key> or <key>=<value> syntax)
    -all : [optional] Dump all objects, including unreachable objects (BOOLEAN, false)

通过帮助手册可以查看到,生成HPROF格式的堆dump,可以指定-all命令就能dump所有的对象,包括那些无法到达的对象。
命令指定的路径是相对于JVM运行的当前路径,所以最好还是指定一个全路径。
Dump生成之后就可以使用VisualVM等工具进行分析了,详细的分析流程在后续会陆续讲到。

可能很多小伙伴使用过jmap工具,也一样可以生成dump文件,不过未来版本可能会被去掉,Oracle官方也建议使用jcmd。

2.4生成类直方图

类直方图是一个较为直观的状态去查看内存分布的情况。

>jcmd <PID> GC.class_histogram

 num     #instances         #bytes  class name
----------------------------------------------
   1:          5923        5976952  [I
   2:         50034        4127704  [C
   3:         49465        1187160  java.lang.String
   4:           188        1069496  [J
   5:          3985        1067240  [Ljava.util.HashMap$Node;
   6:          8756         982872  java.lang.Class
   7:          2855         835792  [B
   8:         23570         754240  java.util.HashMap$Node
   9:         13964         671440  [Ljava.lang.Object;
  10:          9642         308544  java.util.Hashtable$Entry
  11:          4453         213744  java.util.HashMap

上述对象描述的只是类自身大小,不包含子对象。上图中String底层实现使用到了char[],但是很明显char[]并未比String大多少。

2.5打印线程状态

有时候我们的应用程序会产生死锁或者频繁争抢资源的情况,那么就可以通过打印线程状态来详细分析各个线程的执行状态。

jstack <PID>
jcmd <PID> Thread.print

3.总结

我们对jcmd有了一个直观的认识,下面的文章中将会对各种线上故障通过jcmd进行一一解决。

参考资料: Java Performance Tuning Guide

作者:BrianXia
转载请注明 https://www.jianshu.com/p/bc2ff6829d2d

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,506评论 11 349
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,161评论 19 139
  • 参考自 http://techblog.youdao.com/?p=961 在分析具体故障,先介绍一下几种常用的工...
    抓兔子的猫阅读 11,420评论 1 27
  • ESPN记者Brian Windhorst曝出了这个休赛期的又一个重磅消息,凯里-欧文向克里夫兰骑士队提出交易申请...
    殿堂NBA阅读 3,607评论 0 1
  • 很多事情你做错了,认为可以回头,你以为你以为的就是你以为的吗,也要看看对面还有没有人愿意给你一次机会,愿意原地等...
    蒹葭16阅读 1,436评论 0 0

友情链接更多精彩内容