Java虚拟机学习总结(3)——JDK内置工具(jps、jstack、jmap、jstat)使用详解
一、JDK内置工具 - javap1、 介绍java 反编译工具,主要用于根据Java字节码文件反汇编为Java源代码文件。2、命令javap <options> <classes>3、命令集-help --help -? 输出此用法消息-version 版本信息,其实是当前javap所在jdk的版本信息,不是class在哪个j...
一、JDK内置工具 - javap
1、 介绍
java 反编译工具,主要用于根据Java字节码文件反汇编为Java源代码文件。
2、命令
javap <options> <classes>
3、命令集
-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
1、介绍
jps (Java Virtual Machine Process Status Tool) 显示当前所有java金城pid的命令
2、命令
jps <options> <hostid>
3、命令集
-q 只输出进程 ID -m 输出传入 main 方法的参数 -l 输出完全的包名,应用主类名,jar的完全路径名 -v 输出jvm参数 -V 输出通过flag文件传递到JVM中的参数 -Joption 传递参数到vm,例如:-J-Xms512m
三、JDK内置工具 -jstat
1、介绍
jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。
2、命令
jstat [generalOption | outputOptions vmid [ interval [ s|ms ] [ count ] ] ]
3、命令合集
-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
1、介绍
看Java进程、导出线程信息、执行GC、还可以进行采样分析(jmc 工具的飞行记录器)。
2、命令
jcmd <pid | main class> <command ... | PerfCounter.print | -f file>
3、命令合集
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
1、介绍
主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。
2、命令
jinfo <option> <pid>
3、命令合集
-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
1、介绍
看Java进程、导出线程信息、执行GC、还可以进行采样分析(jmc 工具的飞行记录器)。
2、命令
jcmd <pid | main class> <command ... | PerfCounter.print | -f file>
3、命令合集
参数说明 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
1、介绍
主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。
2、命令
jinfo <option> <pid>
3、命令合集
-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
1、介绍
主要是用来分析java堆的命令,可以将堆中的对象以html的形式显示出来,包括对象的数量,大小等等,并支持对象查询语言。
2、命令
jhat [ options ] heap-dump-file
3、命令合集
-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
1、介绍
主要用于打印配置信息,包括命令行参数、系统变量。极少数的情况下,我们可以用其来修改命令行参数。
2、命令
jinfo <option> <pid>
3、命令合集
-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
1、介绍
打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。它的用途是为了展示java进程的内存映射信息,或者堆内存详情。
2、命令
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)
3、命令合集
-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
1、介绍
查看堆内各个部分的使用量,以及加载类的数量。使用时,需加上查看进程的进程id,和所选参数。
2、命令
jhat -options
3、命令合集
十二、JDK内置工具 - jconsole
1、介绍
一个内置 Java 性能分析器,可以从命令行或在 GUI shell 中运行。您可以轻松地使用 JConsole(或者,它更高端的 “近亲” VisualVM )来监控 Java 应用程序性能和跟踪 Java 中的代码。
2、命令
windows的bin目录里面
3、界面
查看,参看堆内存,非堆内存,内存池的状况总体内存的分配和使用情况以及不同的GC进行垃圾回收的次数和时间。可以手动进行GC查看内存变化。在分析JAVA内存问题进行调优时候非常有用,你要学习JVM内存模型,之后会发现这里的每个值都具有意义。 GC的算法和参数对性能有显著的影响,注意垃圾回收次数、时间、以及partial GC和full GC,调整所使用的不同GC和以及各个GC下的参数,然后在这个视图下观察,以得到好的性能。现在流行微服务,同一个服务可能是多台,所以这个命令更多的使用在测试环境单台机器上。
十三、JDK内置工具 - jvisualvm
1、介绍
用来监控JVM的运行情况,可以用它来查看和浏览Heap Dump、Thread Dump、内存对象实例情况、GC执行情况、CPU消耗以及类的装载情况
2、命令
windows的bin目录里面
3、 界面
VisualVM,能够监控线程,内存情况,查看方法的CPU时间和内存中的对 象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的).从界面上看还是比较简洁的,左边是树形结构,自动显示当前本机所运行的Java程序,还可以添加远程的Java VM,其中括号里面的PID指的是进程ID。OverView界面显示VM启动参数以及该VM对应的一些属性。Monitor界面则是监控Java堆大小,Permgen大小,Classes和线程数量。
更多推荐
所有评论(0)