zoukankan      html  css  js  c++  java
  • 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
    

    部分输出内容如下:

    image

    其中,"="表示的是初始值,":="表示的是修改过后的值。
    这条命令查看的是执行java命令的当前进程,正式使用中,通常我们查看的是线上的Java程序进程,这时,就会用到JDK命令行工具:jpsjinfo

    所有的JDK工具都可以在Oracle官网的 Java Tools Reference 文档中找到使用说明,这是主要参考。

    jps

    JDK自带了一些命令行工具,其中jps和Linux命令ps一样,都是查看进程的,不过jps只用来查看Java进程。

    格式:jps [ options ] [ hostid ]
    

    查看jps的帮助信息:

    image

    使用jps命令查看本地Java进程:

    image

    输出Bootstrap的是Tomcat进程,可以使用jps -l输出包路径来确认:

    image

    使用jps -v查看更多的参数:

    image

    jinfo

    jinfo命令用来查看JVM的配置信息。

    格式:
    jinfo [ option ] pid
    jinfo [ option ] executable core
    jinfo [ option ] [ servier-id ] remote-hostname-or-IP
    

    查看jinfo的帮助信息:

    image

    使用jinfo -flag [参数] [pid]查看Java堆的最大值:

    image

    查看是否使用了G1或者Parallel的收集器:

    image

    使用jinfo -flags [pid]查看所有修改过的参数值:

    image

    总结

    先通过jps命令找到要查看的Java进程,再使用jinfo命令就可以查看指定Java程序的运行时参数了。

  • 相关阅读:
    使用linux将一个服务器上的文件或者文件夹复制黏贴到另一个服务器上
    深度学习之常用linux命令总结
    python 操作MYSQL数据库
    MYSQL登录及常用命令
    mysql数据库可视化工具—Navicat Premium—安装与激活
    Mysql数据库的简单介绍与入门
    java 正则匹配int型
    js设置文本框只能输入数字
    Java数据抓取(一)
    Nodejs的多线程
  • 原文地址:https://www.cnblogs.com/cellei/p/12164708.html
Copyright © 2011-2022 走看看