weixiaohuai 2019-06-29
这些工具大多数是tools.jar类库的一层薄的包装,它们的主要功能代码是在tools类库中实现的。还有一些甚至就是由Shell脚本直接生成的。
名称 | 作用 | |
---|---|---|
jps | JVM Process Status Tool,显示指定系统内所有的HotSpot虚拟机进程 | |
jstat | JVM Statistics Monitoring Tool,用于收集HotSpot虚拟机各方面的运行数据 | |
jinfo | Configuration Info for Java,显示虚拟机配置信息 | |
jmap | Memory Map for Java,生成虚拟机的内存转储快照(heapdump文件) | |
jhat | JVM Heap Dump Browser,用于分析heapmap文件,它会建立一个http/html服务器让用户可以在浏览器上查看分析结果 | |
jstack | Stack Trace for Java,显示虚拟机的线程快照 |
jsp [options] [hostid]
属性 | 作用
-p | 只输出LVMID,省略主类的名称
-m | 输出虚拟机进程启动时传递给主类main()函数的参数
-l | 输出主类的全名,如果进程执行的是jar包,输出jar路径
-v | 输出虚拟机进程启动时jvm参数
jstat是用于监视虚拟机各种运行状态信息的命令行工具。它可以显示本地或者远程虚拟机进程中的类装载、内存、垃圾回收、JIT编译等运行数据,在没有GUI图形界面,只是提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的首选工具。
jstat [option vmid [interval [s|ms] [count]]]
[protocol:] [//] lvmid[@hostname[:port]/servername]
选项 | 作用 |
---|---|
-class | 监视装载类、卸载类、总空间以及类装载所耗费的时间 |
-gc | 监视java堆状况,包括eden区、两个survivor区、老年代、永久代等的容量、已用空间、GC时间合计信息 |
-gccapacity | 监视内容与-gc基本相同,但输出主要关注java堆各个区域使用到最大、最小空间 |
-gcutil | 监视内容与-gc基本相同,但输出主要关注已使用控件占总空间的百分比 |
-gccause | 与-gcutil功能一样,但是会额外输出导致上一次gc产生的原因 |
-gcnew | 监视新生代GC情况 |
-gcnewcapacity | 监视内容与-gcnew基本相同,输出主要关注使用到的最大、最小空间 |
-gcold | 监视老年代GC情况 |
-gcoldcapacity | 监视内容与-gcold基本相同,输出主要关注使用到的最大、最小空间 |
-gcpermcapacity | 输出永久代使用到的最大、最小空间 |
-compiler | 输出JIT编译过的方法、耗时等信息 |
-printcompilation | 输出已经被JIT编译过的方法 |
jinfo的作用是实时的查看和调整虚拟机各项参数。
jinfo [option] pid
选项 | 作用 |
---|---|
-flag <name> | to print the value of the named VM flag |
-flag [+/-]<name> | to enable or disable the named VM flag |
-flag <name>=<value> | to set the named VM flag to the given value |
-flags | to print VM flags |
-sysprops | to print Java system properties |
<no option> | to print both of the above |
-h / -help | to print this help message |
jmap [option] vmid
选项 | 作用 |
---|---|
-dump | 生成java堆转储快照。格式为: -dump:[live,]format=b,file=<filename>,其中live子参数说明是否只dump出存活的对象 |
-finalizerinfo | 显示在F-Queue中等待Finalizer线程执行finalize方法的对象。只在Linux/Solaris平台下有效 |
-heap | 显示java堆详细信息,如使用哪种收集器、参数配置、分代情况等,在Linux/Solaris平台下有效 |
-jisto | 显示堆中对象统计信息,包含类、实例对象、合集容量 |
-permstat | 以ClassLoader为统计口径显示永久代内存状态。只在Linux/Solaris平台下有效 |
-F | 当虚拟机进程对-dump选项没有相应时。可使用这个选项强制生成dump快照。只在Linux/Solaris平台下有效 |
jhat [ options ] heap-dump-file
jstack [option] vmid
选项 | 作用 |
---|---|
-F | 当正常输出的请求不被响应时,强制输出线程堆栈 |
-l | 除堆栈外,显示关于锁的附加信息 |
-m | 如果调用到本地方法的话,可以显示c/c++的堆栈 |
JConsole ( Java Monitoring and Management Console ) 是—种基于JMX的可视化监视管理工具。它管理部分的功能是针对JMX MBean进行管理,由于MBean可以使用代码、中间件服务器的管理控制台或者所有符合JMX规范的软件进行访问。
“概述”页签显示的是整个虚拟机主要运行数据的概览,其中包括“堆内存使用情况”、“线程”、“类”、“CPU使用情况”4种信息的曲线图
“内存”页签相当于可视化的jstat命令,用于监视受收集器管理的虚拟机内存(Java堆和永久代)的变化趋势。
“线程”页签的功能相当于可视化的jstack命令,遇到线程停顿时可以使用这个页签进行监控分析。
VisualVM(All-in-One Java Troubleshooting Tool)是到目前为止随JDK发布的功能最强大的运行监视和故障处理程序,并且可以预见在未来一段时间内都是官方主力发展的虚拟机故障处理工具。官方在VisualVM的软件说明中写上了“All-in-One” 的描述字样,预示着它除了运行监视、故障处理外,还提供了很多其他方面的功能。如性能分析,VisualVM的性能分析功能甚至比起JProfiler、YourKit等专业且收费的Profiling工具都不会逊色多少,而且VisualVM的还有一个很大的优点:不需要被监视的程序基于特殊Agent运行,因此它对应用程序的实际性能的影响很小,使得它可以直接应用在生产环境中。这个优点是JProfiler、YourKit等工具无法与之媲美的。
VisualVM基于NetBeans平台开发,因此它一开始就具备了插件扩展功能的特性,通过插件扩展支持,VisualVM可以做到:
在VisualVM中生成dump文件有两种方式,可以执行下列任一操作:
在Profiler页签中,VisualVM提供了程序运行期间方法级的CPU执行时间分析以及内存分析,做Profiling分析肯定会对程序运行性能有比较大的影响,所以一般不在生产环境中使用这项功能。
BTrace本身也是可以独立运行的程序。它的作用是在不停止目标程序运行的前提下,通过HotSpot虚拟机的HotSwap技术动态加入原本并不存在的调试代码。这项功能对实际生产中的程序很有意义:经常遇到程序出现问题,但排查错误的一些必要信息,譬如方法参数、返回值等,在开发时并没有打印到日志之中,以至于不得不停掉服务,通过调试增量来加入日志代码以解决问题。当遇到生产环境服务无法随便停止时,缺一两句日志导致排错进行不下去是一件非常郁闷的事情。BTrace的用法还有许多,打印调用堆栈、参数、返回值只是最基本的应用,在它的网站上有使用BTrace进行性能监视、定位连接泄漏和内存泄漏、解决多线程竞争问题的例子。