首页 > 其他 > 详细

JVM探秘:jinfo查看JVM运行时参数

时间:2020-02-10 11:33:39      阅读:76      评论:0      收藏:0      [点我收藏+]
本系列笔记主要基于《深入理解Java虚拟机:JVM高级特性与最佳实践 第2版》,是这本书的读书笔记。
如何查看JVM运行时参数,对于线上JVM调优是很关键的,因为只有知道了当前使用的JVM参数是什么值,才能知道如何进行调优。
以下JVM参数,可以用来打印JVM运行时参数及它们的值:
参数说明
-XX:+PrintFlagsInitial查看初始值
-XX:+PrintFlagsFinal查看最终的值,因为初始值有可能被修改
-XX:+UnlockExperimentalVMOptions解锁实验参数,JVM中有些实验参数无法直接赋值,必须先使用此参数才能赋值
-XX:+UnlockDiagnosticVMOptions解锁诊断参数
-XX:+PrintCommandLineFlags打印命令行参数
例如,使用PrintFlagsFinal命令查看JVM参数
Copy
java -XX:+PrintFlagsFinal -version
部分输出内容如下:
技术分享图片
其中,"="表示的是初始值,":="表示的是修改过后的值。
这条命令查看的是执行java命令的当前进程,正式使用中,通常我们查看的是线上的Java程序进程,这时,就会用到JDK命令行工具:jps和jinfo。
所有的JDK工具都可以在Oracle官网的 Java Tools Reference 文档中找到使用说明,这是主要参考。
jps#
JDK自带了一些命令行工具,其中jps和Linux命令ps一样,都是查看进程的,不过jps只用来查看Java进程。
Copy
格式:jps [ options ] [ hostid ]
查看jps的帮助信息:
技术分享图片
使用jps命令查看本地Java进程:
技术分享图片
输出Bootstrap的是Tomcat进程,可以使用jps -l输出包路径来确认:
技术分享图片
使用jps -v查看更多的参数:
技术分享图片
jinfo#
jinfo命令用来查看JVM的配置信息。
Copy
格式:jinfo [ option ] pidjinfo [ option ] executable corejinfo [ option ] [ servier-id ] remote-hostname-or-IP
查看jinfo的帮助信息:
技术分享图片
使用jinfo -flag [参数] [pid]查看Java堆的最大值:
技术分享图片
查看是否使用了G1或者Parallel的收集器:
技术分享图片
使用jinfo -flags [pid]查看所有修改过的参数值:
技术分享图片
总结#
先通过jps命令找到要查看的Java进程,再使用jinfo命令就可以查看指定Java程序的运行时参数了。

JVM探秘:jinfo查看JVM运行时参数

原文:https://www.cnblogs.com/zhuxiaopijingjing/p/12289996.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!