首页 技术 正文
技术 2022年11月15日
0 收藏 856 点赞 3,690 浏览 1011 个字

本系列笔记主要基于《深入理解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命令行工具:jpsjinfo

所有的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开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,493
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,132
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,294