zoukankan      html  css  js  c++  java
  • JVM优化之VisualVM工具的使用

    什么是VisualVM?

    VisualVM,能够监控线程,内存情况,查看方法的CPU时间和内存中的对 象,已被GC的对象,

    反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的)。

    VisualVM使用简单,几乎0配置,功能还是比较丰富的,几乎囊括了其它JDK自带命令的所有功能

    • 内存信息
    • 线程信息
    • Dump堆(本地进程)
    • Dump线程(本地进程)
    • 打开堆Dump。堆Dump可以用jmap来生成。
    • 打开线程Dump
    • 生成应用快照(包含内存信息、线程信息等等)
    • 性能分析。CPU分析(各个方法调用时间,检查哪些方法耗时多),内存分析(各类对象占用的内存,检查哪些类占用内存多)
    • ...........

    启动

    在jdk的安装目录的bin目录下,找到jvisualvm.exe,双击打开即可。

     查看本地进程

    查看CPU、内存、类、线程运行信息

    查看线程详情

     

    也可以点击右上角Dump按钮,将线程的信息导出,其实就是执行的jstack命令。

    抽样器

    抽样器可以对CPU、内存在一段时间内进行抽样,以供分析。

    抽样内存

     抽样cpu

    监控远程的jvm
    VisualJVM不仅是可以监控本地jvm进程,还可以监控远程的jvm进程,需要借助于JMX技术实现。

    什么是JMX?

    JMX(Java Management Extensions,即Java管理扩展)是一个为应用程序、设备、系统等植入管理功能的框架。

    JMX可以跨越一系列异构操作系统平台、系统体系结构和网络传输协议,灵活的开发无缝集成的系统、网络和服务管理应用。

    监控远程的tomcat

    想要监控远程的tomcat,就需要在远程的tomcat进行对JMX配置,方法如下:

    注意:要将该的配置放在catalina.sh的上面,否则将无法创建JMX连接

    #在tomcat的bin目录下,修改catalina.sh,添加如下的参数
    JAVA_OPTS="‐Dcom.sun.management.jmxremote ‐
    Dcom.sun.management.jmxremote.port=9999 ‐
    Dcom.sun.management.jmxremote.authenticate=false ‐
    Dcom.sun.management.jmxremote.ssl=false"
    #这几个参数的意思是:
    #‐Dcom.sun.management.jmxremote :允许使用JMX远程管理
    #‐Dcom.sun.management.jmxremote.port=9999 :JMX远程连接端口
    #‐Dcom.sun.management.jmxremote.authenticate=false :不进行身份认证,任何用
    户都可以连接
    #‐Dcom.sun.management.jmxremote.ssl=false :不使用ssl
    

      

     

    接下来就监控远程JVM

  • 相关阅读:
    Unity调试模式设置辅助线是否可见
    Gizmos绘制塔防游戏网格
    JS offsetparent 问题
    JS 图像延迟加载
    JS image对象
    JS 瀑布流
    JS 对象
    JS node
    Vue+element 实现表格的增加行、根据索引删除行的功能
    Java的集合框架
  • 原文地址:https://www.cnblogs.com/wishsaber/p/12411872.html
Copyright © 2011-2022 走看看