• IDEA安装使用 VisualVM 及VisualVM 远程监视


    1. VisualVM是什么

    按照VisualVM官网(http://visualvm.github.io/)上的介绍,VisualVM是一个集成命令行JDK工具和轻量级分析功能的可视化工具。专为开发和生产时间使用而设计。

    我们在jdk安装包中也可以发现它

    2. IDEA安装VisualVM插件

    File-> Setting-> Plugins -> Browers Repositrories 搜索VisualVM Launcher安装并重启IDEA。

    出现上图中的两个按钮即为安装成功,当我们通过他们启动项目时,会自动打开VisualVM控制台面板。

    3. VisualVM本地使用

    右侧有概述(Overview)、监视(Monitor)、线程(Threads)、抽样器(Sampler)几个标签,其中

    • 概述中可以看到程序的基本信息和启动参数、环境变量等等;
    • 监视是几个折线图,用于显示CPU、内存(分为Heap和Metaspace)、类和线程的使用情况或者数量,另外还包括执行垃圾回收和对堆 Dump的快捷功能;
    • 线程可详细查看每个线程的运行时间及状态等;
    • 抽样器可对CPU和内存进行一段时长的取样,从而对应用程序进行分析。

    使用时,可通过监视中的各个折线图查看系统的变化,如果执行某段程序时,某个指标出现突然增大等问题,同时程序运行也出现问题,可进入到该面板做细致检查。

    如果某段程序执行时CPU飙升或者内存溢出,此时排除系统性能原因,多半是由于低效的代码或者不合理的堆空间分配引起,可以在复现该问题的同时到抽样器面板进行抽样,从而确定应该优化哪个方法或者分配多大内存。

    当对一个多线程应用程序进行调试或者开发后期做性能调优的时候,往往需要了解当前程序中所有线程的运行状态,是否有死锁、热锁等情况的发生,从而分析系统可能存在的问题。在 VisualVM 的监视标签和线程标签内,我们可以查看当前应用程序中所有活动线程(Live threads)和守护线程(Daemon threads)的数量等实时信息。

    具体使用方法很直观,不再一一介绍,如果要进行测试,可参考该篇博客:http://www.cnblogs.com/wade-xu/p/4369094.html 

    4. 远程监视

    在实际工作中,需要在本机监控的生产环境下的jvm,Visualvm目前支持两种remote connection方式,分别是jstatd和JMX方式: 这里主要介绍的是通过JMX方式.。

    4.1 修改远程jvm配置

    进入JAVA_HOMEjrelibmanagement,拷贝一份jmxremote.password.template 并改名为 jmxremote.password到当前目录,并去掉# monitorRole  QED 和 # controlRole  R&D 这两行前面的注释符号。

     

    [root@izbp1cq2wdg9kxunr0sz02z ~]# cd /usr/java/jdk/jdk1.8.0_172/jre/lib/management
    [root@izbp1cq2wdg9kxunr0sz02z management]# cp jmxremote.password.template jmxremote.password
    [root@izbp1cq2wdg9kxunr0sz02z management]# ls
    jmxremote.access  jmxremote.password  jmxremote.password.template  management.properties  snmp.acl.template
    [root@izbp1cq2wdg9kxunr0sz02z management]# vim jmxremote.password
    [root@izbp1cq2wdg9kxunr0sz02z management]# chmod 600 jmxremote.password
    [root@izbp1cq2wdg9kxunr0sz02z management]# chown root jmxremote.password

    我这里使用的是默认的两个远程控制账号,如果在 jmxremote.password 中自定义了远程登录账号和密码,需要修改同目录下的jmxremote.access 文件,该文件可以控制访问权限。

    4.2 修改远程机器上需要被监控的程序的配置文件 

    我这里是监控Tomcat容器内部署的应用

    修改TOMCAT_HOME/bin/catalian.sh文件,添加

    export JAVA_OPTS="-Djava.rmi.server.hostname=47.xx.xxx.xx1 -Dcom.sun.management.jmxremote.port=18999  -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=true"

    详细参数如下

     参数描述
    com.sun.management.jmxremote true / false. Default is true
    com.sun.management.jmxremote.port Port number. No default.
    com.sun.management.jmxremote.ssl true / false. Default is true.
    com.sun.management.jmxremote.ssl.enabled.protocols Default SSL/TLS protocol version.
    com.sun.management.jmxremote.ssl.enabled.cipher.suites Default SSL/TLS cipher suites.
    com.sun.management.jmxremote.ssl.need.client.auth true / false. Default is false
    com.sun.management.jmxremote.authenticate true / false.Default is true
    com.sun.management.jmxremote.password.file JRE_HOME/lib/management/jmxremote.password
    com.sun.management.jmxremote.access.file JRE_HOME/lib/management/jmxremote.access
    com.sun.management.jmxremote.login.config Default login configuration is a file-based password authentication

    重启tomcat。

    可以用 netstat -anp| grep 18999 ,查看守护线程是否已经启动。

    4.3 VisualVM配置

  • 相关阅读:
    Mysql备份工具xtraback全量和增量测试
    Linux进程管理四大工具ps dstat top htop
    Linux Netcat 命令——网络工具中的瑞士军刀
    Linux 下载工具 aria2
    C语言宏基础总结
    使用浏览器做编辑器
    设计模式(1)
    OpenGL 编程(1)
    使用ffmpeg推流
    FFMPEG 解码和编码(编码mjpeg)
  • 原文地址:https://www.cnblogs.com/zjfjava/p/9820994.html
Copyright © 2020-2023  润新知