JVM(五)JVM优化之工具「建议收藏」

JVM(五)JVM优化之工具「建议收藏」前言本章讲解JVM优化中常见的工具的使用方法1.概念在JVM优化的道路上,任重道远,我们需要借助JDK本身的工具进行分析。2.工具详情下面介绍的小工具均在JAVA_HOME/bin下,我的路径是这样的。1)jps:JVMProcessStatusTool,显示系统内所有的JVM进程语法: -q 只输出LVMID,省略主类名称; …

大家好,又见面了,我是你们的朋友全栈君。

前言

      本章讲解JVM优化中常见的工具的使用

方法

1.概念

在JVM优化的道路上,任重道远,我们需要借助JDK本身的工具进行分析。

2.工具详情

下面介绍的小工具均在JAVA_HOME/bin下,我的路径是这样的。

JVM(五)JVM优化之工具「建议收藏」

1)jps:JVM Process Status Tool,显示系统内所有的JVM进程

语法:

  • -q
    只输出LVMID,省略主类名称;

  • -m
    输出虚拟机进程启动时传给主类函数的参数;

  • -l
    输出主类的完成package名称或者jar包完整路径名;

  • -v
    输出虚拟机启动时的JVM参数

使用示例:
JVM(五)JVM优化之工具「建议收藏」

2)jstat:JVM Statistics Monitoring Tool,可以收集JVM相关的运行数据

语法:

jstat命令稍许有些复杂,它主要有以下参数:

  1. option:选项,jstat主要提供以下选项:

    • -class
      监视类的装载/卸载数量、总空间以及类装载所耗时间;

    • -gc
      监视java heap情况,包括eden区和两个survivor区、old区、永久区等的容量,已用空间和GC时间等信息;

    • -gccapacity
      监视内容与-gc基本是一致的,-gccapacity的输出包括heap各个区域使用到的最大最小空间;

    • gcutil
      监视内容同样与-gc基本一致,-gcutil的输出主要是heap各个区域使用空间占总空间百分比;

    • gccause
      -gcutil功能一致,但是会额外输出导致上一次gc的原因;

    • gcnew
      监视young区gc情况;

    • gcnewcapacity
      监视内容与-gcnew基本相同,-gcnewcapacity的输出包括使用到的最大最小空间;

    • -gcold
      监视old区gc情况;

    • -gcoldcapacity
      监视内容与-gcold基本相同,-gcoldcapacity的输出包括使用到的最大最小空间;

    • -gcpermcapacity
      输出永久代使用到的最大最小空间。注意:JDK 8废除了永久代,引入了Metaspace,这个命令在JDK 8的环境下就不能使用了,那要看元数据空间相关情况,使用-gcmetacapacity即可

    • -compiler
      输出JIT编译器编译过的方法以及耗时等信息;
    • -printcompilation
      输出以及被JIT编译的方法
  2. vmid:虚拟机进程id,这时候小伙伴们肯定又要开始疑惑了,这个vmid与lvmid又有什么区别?其实对于本地虚拟机进程,它俩没任何区别,但是如果是远程虚拟机进程,它俩就有区别了,远程虚拟机进程vmid格式应该是这样:
    [protocol:][//] lvmid [@hostname[:port]/servername]

  3. interval:查询时间间隔;

  4. count:查询次数。

使用示例:

JVM(五)JVM优化之工具「建议收藏」

其中的内涵大家自行百度。

其他的还有如下的小工具大家可以自行查找。

  • jinfo:Configuration Info for Java,显示JVM配置信息;

  • jmap:Memory Map for Java,用于生成JVM的内存快照;

  • jhat:JVM Heap Dump Browser,用于分析heapdump文件,它可以建立一个http/html服务,使用者可以在浏览器上查看分析结果;

  • jstack:Stack Trace for Java,显示JVM的线程快照。

前面的都是虾兵蟹将,接下来出场的才是重头戏,也就是融合了前面所有工具功能的图形化用户界面jvisualvm

该工具极其强大,是JVM分析的首选!

JVM(五)JVM优化之工具「建议收藏」

附录一:jvisualvm添加GC插件

jvisualvm还有个功能就是可以添加我们所需要的插件,其中GC插件尤为重要!

1.工具->插件

JVM(五)JVM优化之工具「建议收藏」

2.选择可用插件->Visual GC

JVM(五)JVM优化之工具「建议收藏」

3.一路下一步

JVM(五)JVM优化之工具「建议收藏」

4.完成后重启应用程序即可看到如下tab页

JVM(五)JVM优化之工具「建议收藏」

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136504.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • LeetCode解题汇总目录

    此篇为学习完《数据结构与算法之美》后,在LeetCode刷题的汇总目录,方便大家查找(Ctrl+Find),一起刷题,一起PK交流!另有解题:《剑指Offer》、《程序员面试金典》、LintCode代码能力测试CAT。如果本文对你有帮助,可以给我点赞加油!通过2021,简单618/636,中等1120/1266,困难283/488

    2022年4月7日
    33
  • Pytest+Allure安装

    Pytest+Allure安装文章目录1.Pytest环境安装2.Window环境下Allure安装3.Linux环境下Allure安装1.Pytest环境安装#在线安装pip3installpytestpip3installpytest-rerunfailurespip3installpytest-htmlpip3installpytest-repeatpip3installpytest-assumepip3installallure-pytest#离线安装-先在线下载pip3

    2022年7月26日
    3
  • 高等数学 – 数列极限定义 – 笔记

    高等数学 – 数列极限定义 – 笔记数列极限定义是个很让我费解的内容,所以花了一下午的时间去理解它,并将得到的结论记录在此。专科级理解,各路大神敬请指教。

    2022年6月11日
    37
  • python生成器详解_Python 生成器

    python生成器详解_Python 生成器生成器利用迭代器,我们可以在每次迭代获取数据(通过next()方法)时按照特定的规律进行生成。但是我们在实现一个迭代器时,关于当前迭代到的状态需要我们自己记录,进而才能根据当前状态生成下一个数据。

    2022年8月6日
    5
  • acwing321. 棋盘分割(动态规划+记忆化搜索)「建议收藏」

    acwing321. 棋盘分割(动态规划+记忆化搜索)「建议收藏」将一个 8×8 的棋盘进行如下分割:将原棋盘割下一块矩形棋盘并使剩下部分也是矩形,再将剩下的部分继续如此分割,这样割了 (n−1) 次后,连同最后剩下的矩形棋盘共有 n 块矩形棋盘。(每次切割都只能沿着棋盘格子的边进行)原棋盘上每一格有一个分值,一块矩形棋盘的总分为其所含各格分值之和。现在需要把棋盘按上述规则分割成 n 块矩形棋盘,并使各矩形棋盘总分的均方差最小。均方差formula.png ,其中平均值lala.png ,xi 为第 i 块矩形棋盘的总分。请编程对给出的棋盘及 n,求出均方差的最

    2022年8月8日
    1
  • centos7 输入 ifconfig 不显示 ip 地址 连接不上的解决方法(亲测成功)「建议收藏」

    centos7 输入 ifconfig 不显示 ip 地址 连接不上的解决方法(亲测成功)「建议收藏」最近又把自己的虚拟机打开了玩玩集群,遇到一个小问题,我发现虚拟机的内存不够了,就把虚拟机关机加大了内存,谁知道开机后,ifconfig或者ipaddr显示没有ip地址,只显示一个lo,没有ens33,没有ip地址就没法用xshell连接,很蛋疼,网上也有很多解决方案,但都写的乱七八糟的,而且很多都不好使,今天就来介绍一下我最后解决的方法.我说一下我的虚拟机的情况,我三台虚拟机,之前是mas………

    2022年10月23日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号