前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JDK内置命令工具

JDK内置命令工具

作者头像
IT架构圈
发布2021-02-01 15:03:31
4000
发布2021-02-01 15:03:31
举报
文章被收录于专栏:IT架构圈

本次一起说下JDK的内置工具,JDK里面很多强大的工具,查看JVM的信息和监控JVM的内容。

(一)JDK内置工具 - javap
  • ① 介绍

java 反编译工具,主要用于根据Java字节码文件反汇编为Java源代码文件。

  • ② 命令
代码语言:javascript
复制
javap <options> <classes>
  • ③ 命令集
代码语言:javascript
复制
 -help  --help  -?        输出此用法消息
 -version                 版本信息,其实是当前javap所在jdk的版本信息,不是class在哪个jdk下生成的。
 -v  -verbose             输出附加信息(包括行号、本地变量表,反汇编等详细信息)
 -l                         输出行号和本地变量表
 -public                    仅显示公共类和成员
 -protected               显示受保护的/公共类和成员
 -package                 显示程序包/受保护的/公共类 和成员 (默认)
 -p  -private             显示所有类和成员
 -c                       对代码进行反汇编
 -s                       输出内部类型签名
 -sysinfo                 显示正在处理的类的系统信息 (路径, 大小, 日期, MD5 散列)
 -constants               显示静态最终常量
 -classpath <path>        指定查找用户类文件的位置
 -bootclasspath <path>    覆盖引导类文件的位置
(二)JDK内置工具 -jps
  • ① 介绍

jps (Java Virtual Machine Process Status Tool) 显示当前所有java进程pid的命令

  • ② 命令
代码语言:javascript
复制
jps <options> <hostid>
  • ③ 命令集
代码语言:javascript
复制
-q  只输出进程 ID
-m  输出传入 main 方法的参数
-l  输出完全的包名,应用主类名,jar的完全路径名
-v  输出jvm参数
-V  输出通过flag文件传递到JVM中的参数
-Joption 传递参数到vm,例如:-J-Xms512m
(三)JDK内置工具 -jstat
  • ① 介绍

jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。

  • ② 命令
代码语言:javascript
复制
jstat [generalOption | outputOptions vmid [ interval [ s|ms ] [ count ] ] ]
  • ③ 命令合集
代码语言:javascript
复制
-gc pid                    显示gc的信息,查看gc的次数,及时间
-gccapacity pid            VM分代内存的使用和占用大小
-gcutil pid                统计gc信息统计
-gcnew pid                年轻代对象的信息
-gcnewcapacity pid         年轻代对象的信息及其占用量
-gcold pid                  old代对象的信息
-gcoldcapacity pid         old代对象的信息
-gcpermcapacity pid       perm对象的信息及其占用量
-class pid                显示加载class的数量,及所占空间等信息
-compiler pid              显示VM实时编译的数量等信息
-printcompilation pid      当前VM执行的信息
(四)JDK内置工具 - jcmd
  • ① 介绍

看Java进程、导出线程信息、执行GC、还可以进行采样分析(jmc 工具的飞行记录器)。

  • ② 命令
代码语言:javascript
复制
jcmd <pid | main class> <command ... | PerfCounter.print | -f  file>
  • ③ 命令合集
代码语言:javascript
复制
 pid help                             查看本地的java进程列表,获取其pid
pid VM.uptime                         查看 JVM 的启动时长
pid GC.class_histogram                查看 JVM 的类信息,这个可以查看每个类的实例数量和占用空间大小。
pid Thread.print                      查看 JVM 的Thread Dump
pid GC.heap_dump FILE_NAME            查看 JVM 的Heap Dump,注意,如果只指定文件名,默认会生成在启动 JVM 的目录里。
pid VM.system_properties              查看 JVM 的属性信息
pid VM.flags                          查看 JVM 的启动参数,注意,可以看到 -X 和 -XX 的参数信息
pid VM.command_line                   查看 JVM 的启动命令行
pid GC.run_finalization               对 JVM 执行 java.lang.System.runFinalization(),尽量b别去调用这个对象的finalize方法。
pid GC.run                            对 JVM 执行 java.lang.System.gc(),告诉垃圾收集器打算进行垃圾收集,而垃圾收集器进不进行收集是不确定的
PID PerfCounter.print                 查看 JVM 的性能
(四)JDK内置工具 -jinfo
  • ① 介绍

主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。

  • ② 命令
代码语言:javascript
复制
jinfo <option> <pid>
  • ③ 命令合集
代码语言:javascript
复制
-gc pid                    显示gc的信息,查看gc的次数,及时间
-gccapacity pid            VM分代内存的使用和占用大小
-gcutil pid                统计gc信息统计
-gcnew pid                年轻代对象的信息
-gcnewcapacity pid         年轻代对象的信息及其占用量
-gcold pid                  old代对象的信息
-gcoldcapacity pid         old代对象的信息
-gcpermcapacity pid       perm对象的信息及其占用量
-class pid                显示加载class的数量,及所占空间等信息
-compiler pid              显示VM实时编译的数量等信息
-printcompilation pid      当前VM执行的信息
(四)JDK内置工具 - jcmd
  • ① 介绍

看Java进程、导出线程信息、执行GC、还可以进行采样分析(jmc 工具的飞行记录器)。

  • ② 命令
代码语言:javascript
复制
jcmd <pid | main class> <command ... | PerfCounter.print | -f  file>
  • ③ 命令合集
代码语言:javascript
复制
参数说明
pid 对应jvm的进程id
executable core 产生core dump文件
[server-id@]remote server IP or hostname 远程的ip或者hostname,server-id标记服务的唯一性id


option
no option 输出全部的参数和系统属性
-flag name 输出对应名称的参数
-flag [+|-]name 开启或者关闭对应名称的参数
-flag name=value 设定对应名称的参数
-flags 输出全部的参数
-sysprops 输出系统属性
( 五)JDK内置工具 -jinfo
  • ① 介绍

主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。

  • ② 命令
代码语言:javascript
复制
jinfo <option> <pid>
  • ③ 命令合集
代码语言:javascript
复制
-gc pid                    显示gc的信息,查看gc的次数,及时间
-gccapacity pid            VM分代内存的使用和占用大小
-gcutil pid                统计gc信息统计
-gcnew pid                年轻代对象的信息
-gcnewcapacity pid         年轻代对象的信息及其占用量
-gcold pid                  old代对象的信息
-gcoldcapacity pid         old代对象的信息
-gcpermcapacity pid       perm对象的信息及其占用量
-class pid                显示加载class的数量,及所占空间等信息
-compiler pid              显示VM实时编译的数量等信息
-printcompilation pid      当前VM执行的信息
(四)JDK内置工具 - jhat
  • ① 介绍

主要是用来分析java堆的命令,可以将堆中的对象以html的形式显示出来,包括对象的数量,大小等等,并支持对象查询语言。

  • ② 命令
代码语言:javascript
复制
jhat [ options ] heap-dump-file
  • ③ 命令合集
代码语言:javascript
复制
-J< flag >                  因为 jhat 命令实际上会启动一个JVM来执行, 通过 -J 可以在启动JVM时传入一些启动参数. 例如, -J-Xmx512m 则指定运行 jhat 的Java虚拟机使用的最大堆内存为 512 MB. 如果需要使用多个JVM启动参数,则传入多个 -Jxxxxxx
-stack false|true           关闭跟踪对象分配调用堆栈。如果分配位置信息在堆转储中不可用. 则必须将此标志设置为 false. 默认值为 true.
-refs false|true            关闭对象引用跟踪。默认情况下, 返回的指针是指向其他特定对象的对象,如反向链接或输入引用(referrers or incoming references), 会统计/计算堆中的所有对象。
-port port-number           设置 jhat HTTP server 的端口号. 默认值 7000。
-exclude exclude-file       指定对象查询时需要排除的数据成员列表文件。例如, 如果文件列出了 java.lang.String.value , 那么当从某个特定对象 Object o 计算可达的对象列表时, 引用路径涉及 java.lang.String.value 的都会被排除。
-baseline exclude-file      指定一个基准堆转储(baseline heap dump)。在两个 heap dumps 中有相同 object ID 的对象会被标记为不是新的(marked as not being new). 其他对象被标记为新的(new). 在比较两个不同的堆转储时很有用。
-debug int                  设置 debug 级别. 0 表示不输出调试信息。值越大则表示输出更详细的 debug 信息。
-version                    启动后只显示版本信息就退出。

( 五)JDK内置工具 -jinfo
  • ① 介绍

主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。

  • ② 命令
代码语言:javascript
复制
jinfo <option> <pid>
  • ③ 命令合集
代码语言:javascript
复制
-gc pid                    显示gc的信息,查看gc的次数,及时间
-gccapacity pid            VM分代内存的使用和占用大小
-gcutil pid                统计gc信息统计
-gcnew pid                年轻代对象的信息
-gcnewcapacity pid         年轻代对象的信息及其占用量
-gcold pid                  old代对象的信息
-gcoldcapacity pid         old代对象的信息
-gcpermcapacity pid       perm对象的信息及其占用量
-class pid                显示加载class的数量,及所占空间等信息
-compiler pid              显示VM实时编译的数量等信息
-printcompilation pid      当前VM执行的信息
(六)JDK内置工具 - jhat
  • ① 介绍

打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。它的用途是为了展示java进程的内存映射信息,或者堆内存详情。

  • ② 命令
代码语言:javascript
复制
jmap [ option ] pid  (to connect to remote debug server)   
jmap [ option ] executable core  (to connect to remote debug server)   
jmap [ option ] [server-id@]remote-hostname-or-IP  (to connect to remote debug server)
  • ③ 命令合集
代码语言:javascript
复制
-histo[:live] <pid>                            通过histo选项,打印当前java堆中各个对象的数量、大小。如果添加了live,只会打印活跃的对象。
-dump:[live,]format=b,file=<filename> <pid>    通过-dump选项,把java堆中的对象dump到本地文件,然后使用MAT进行分析。
如果添加了live,只会dump活跃的对象。
-heap <pid>                                    通过-heap选项,打印java堆的配置情况和使用情况,还有使用的GC算法。
-finalizerinfo <pid>                           通过-finalizerinfo选项,打印那些正在等待执行finalize方法的对象。
-permstat <pid>                                通过-permstat选项,打印java堆永久代的信息,包括class loader相关的信息,和interned Strings的信息。

(七)JDK内置工具 - jhat
  • ① 介绍

查看堆内各个部分的使用量,以及加载类的数量。使用时,需加上查看进程的进程id,和所选参数。

  • ② 命令
代码语言:javascript
复制
jhat -options
  • ③ 命令合集
(八)JDK内置工具 - jconsole
  • ① 介绍

一个内置 Java 性能分析器,可以从命令行或在 GUI shell 中运行。您可以轻松地使用 JConsole(或者,它更高端的 “近亲” VisualVM )来监控 Java 应用程序性能和跟踪 Java 中的代码。

  • ② 命令 windows的bin目录里面
  • ③ 界面

查看,参看堆内存,非堆内存,内存池的状况总体内存的分配和使用情况以及不同的GC进行垃圾回收的次数和时间。可以手动进行GC查看内存变化。在分析JAVA内存问题进行调优时候非常有用,你要学习JVM内存模型,之后会发现这里的每个值都具有意义。GC的算法和参数对性能有显著的影响,注意垃圾回收次数、时间、以及partial GC和full GC,调整所使用的不同GC和以及各个GC下的参数,然后在这个视图下观察,以得到好的性能。

现在流行微服务,同一个服务可能是多台,所以这个命令更多的使用在测试环境单台机器上。

(八)JDK内置工具 - jvisualvm
  • ① 介绍

用来监控JVM的运行情况,可以用它来查看和浏览Heap Dump、Thread Dump、内存对象实例情况、GC执行情况、CPU消耗以及类的装载情况

  • ② 命令 windows的bin目录里面
  • ③ 界面

VisualVM,能够监控线程,内存情况,查看方法的CPU时间和内存中的对 象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的). 从界面上看还是比较简洁的,左边是树形结构,自动显示当前本机所运行的Java程序,还可以添加远程的Java VM,其中括号里面的PID指的是进程ID。OverView界面显示VM启动参数以及该VM对应的一些属性。Monitor界面则是监控Java堆大小,Permgen大小,Classes和线程数量。

插件丰富

PS:两个可视化工具命令可以实现工具,让大家看的更加直观,并不是没有这些工具不行,而是有了这些工具更加方便。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-01-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编程坑太多 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • (一)JDK内置工具 - javap
  • (二)JDK内置工具 -jps
  • (三)JDK内置工具 -jstat
  • (四)JDK内置工具 - jcmd
  • (四)JDK内置工具 -jinfo
  • (四)JDK内置工具 - jcmd
  • ( 五)JDK内置工具 -jinfo
  • (四)JDK内置工具 - jhat
  • ( 五)JDK内置工具 -jinfo
  • (六)JDK内置工具 - jhat
  • (七)JDK内置工具 - jhat
  • (八)JDK内置工具 - jconsole
  • (八)JDK内置工具 - jvisualvm
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档