本次一起说下JDK的内置工具,JDK里面很多强大的工具,查看JVM的信息和监控JVM的内容。
java 反编译工具,主要用于根据Java字节码文件反汇编为Java源代码文件。
javap <options> <classes>
-help --help -? 输出此用法消息
-version 版本信息,其实是当前javap所在jdk的版本信息,不是class在哪个jdk下生成的。
-v -verbose 输出附加信息(包括行号、本地变量表,反汇编等详细信息)
-l 输出行号和本地变量表
-public 仅显示公共类和成员
-protected 显示受保护的/公共类和成员
-package 显示程序包/受保护的/公共类 和成员 (默认)
-p -private 显示所有类和成员
-c 对代码进行反汇编
-s 输出内部类型签名
-sysinfo 显示正在处理的类的系统信息 (路径, 大小, 日期, MD5 散列)
-constants 显示静态最终常量
-classpath <path> 指定查找用户类文件的位置
-bootclasspath <path> 覆盖引导类文件的位置
jps (Java Virtual Machine Process Status Tool) 显示当前所有java进程pid的命令
jps <options> <hostid>
-q 只输出进程 ID
-m 输出传入 main 方法的参数
-l 输出完全的包名,应用主类名,jar的完全路径名
-v 输出jvm参数
-V 输出通过flag文件传递到JVM中的参数
-Joption 传递参数到vm,例如:-J-Xms512m
jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。
jstat [generalOption | outputOptions vmid [ interval [ s|ms ] [ count ] ] ]
-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执行的信息
看Java进程、导出线程信息、执行GC、还可以进行采样分析(jmc 工具的飞行记录器)。
jcmd <pid | main class> <command ... | PerfCounter.print | -f file>
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 的性能
主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。
jinfo <option> <pid>
-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执行的信息
看Java进程、导出线程信息、执行GC、还可以进行采样分析(jmc 工具的飞行记录器)。
jcmd <pid | main class> <command ... | PerfCounter.print | -f file>
参数说明
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 输出系统属性
主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。
jinfo <option> <pid>
-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执行的信息
主要是用来分析java堆的命令,可以将堆中的对象以html的形式显示出来,包括对象的数量,大小等等,并支持对象查询语言。
jhat [ options ] heap-dump-file
-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 启动后只显示版本信息就退出。
主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。
jinfo <option> <pid>
-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执行的信息
打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。它的用途是为了展示java进程的内存映射信息,或者堆内存详情。
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)
-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的信息。
查看堆内各个部分的使用量,以及加载类的数量。使用时,需加上查看进程的进程id,和所选参数。
jhat -options
一个内置 Java 性能分析器,可以从命令行或在 GUI shell 中运行。您可以轻松地使用 JConsole(或者,它更高端的 “近亲” VisualVM )来监控 Java 应用程序性能和跟踪 Java 中的代码。
查看,参看堆内存,非堆内存,内存池的状况总体内存的分配和使用情况以及不同的GC进行垃圾回收的次数和时间。可以手动进行GC查看内存变化。在分析JAVA内存问题进行调优时候非常有用,你要学习JVM内存模型,之后会发现这里的每个值都具有意义。GC的算法和参数对性能有显著的影响,注意垃圾回收次数、时间、以及partial GC和full GC,调整所使用的不同GC和以及各个GC下的参数,然后在这个视图下观察,以得到好的性能。
现在流行微服务,同一个服务可能是多台,所以这个命令更多的使用在测试环境单台机器上。
用来监控JVM的运行情况,可以用它来查看和浏览Heap Dump、Thread Dump、内存对象实例情况、GC执行情况、CPU消耗以及类的装载情况
VisualVM,能够监控线程,内存情况,查看方法的CPU时间和内存中的对 象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的). 从界面上看还是比较简洁的,左边是树形结构,自动显示当前本机所运行的Java程序,还可以添加远程的Java VM,其中括号里面的PID指的是进程ID。OverView界面显示VM启动参数以及该VM对应的一些属性。Monitor界面则是监控Java堆大小,Permgen大小,Classes和线程数量。
插件丰富
PS:两个可视化工具命令可以实现工具,让大家看的更加直观,并不是没有这些工具不行,而是有了这些工具更加方便。