JVM探秘:jinfo查看JVM运行时参数
本系列笔记主要基于《深入理解java虚拟机:jvm高级特性与最佳实践 第2版》,是这本书的读书笔记。
如何查看jvm运行时参数,对于线上jvm调优是很关键的,因为只有知道了当前使用的jvm参数是什么值,才能知道如何进行调优。
以下jvm参数,可以用来打印jvm运行时参数及它们的值:
参数 | 说明 |
---|---|
-xx:+printflagsinitial | 查看初始值 |
-xx:+printflagsfinal | 查看最终的值,因为初始值有可能被修改 |
-xx:+unlockexperimentalvmoptions | 解锁实验参数,jvm中有些实验参数无法直接赋值,必须先使用此参数才能赋值 |
-xx:+unlockdiagnosticvmoptions | 解锁诊断参数 |
-xx:+printcommandlineflags | 打印命令行参数 |
例如,使用printflagsfinal命令查看jvm参数
java -xx:+printflagsfinal -version
部分输出内容如下:
其中,"="
表示的是初始值,":="
表示的是修改过后的值。
这条命令查看的是执行java
命令的当前进程,正式使用中,通常我们查看的是线上的java程序进程,这时,就会用到jdk命令行工具:jps
和jinfo
。
所有的jdk工具都可以在oracle官网的 java tools reference 文档中找到使用说明,这是主要参考。
jps
jdk自带了一些命令行工具,其中jps和linux命令ps一样,都是查看进程的,不过jps只用来查看java进程。
格式:jps [ options ] [ hostid ]
查看jps
的帮助信息:
使用jps
命令查看本地java进程:
输出bootstrap
的是tomcat进程,可以使用jps -l
输出包路径来确认:
使用jps -v
查看更多的参数:
jinfo
jinfo命令用来查看jvm的配置信息。
格式: jinfo [ option ] pid jinfo [ option ] executable core jinfo [ option ] [ servier-id ] remote-hostname-or-ip
查看jinfo
的帮助信息:
使用jinfo -flag [参数] [pid]
查看java堆的最大值:
查看是否使用了g1或者parallel的收集器:
使用jinfo -flags [pid]
查看所有修改过的参数值:
总结
先通过jps
命令找到要查看的java进程,再使用jinfo
命令就可以查看指定java程序的运行时参数了。
上一篇: 元旦的特色食物
下一篇: Python语法速查: 8. 类与对象