• VisualVM工具的使用


    概述

      VisualVM能够监控线程,内存情况,查看方法的CPU时间和内存中的对象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪一个对象分配出来的);

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

        内存信息;

        线程信息;

        Dump堆(本地进程)

        Dump线程(本地进程)

        打开堆Dump, 堆Dump可以用jmap来生成

        打开线程Dump

        生成应用快照(包含内存信息,线程信息等等)

        性能分析,CPU分析(各个方法调用时间,检查哪些方法耗时多),内存分析(各类对象占用的内存,检查哪些类占用内存多)

    1.启动

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

        

        

    2.查看本地进程

      

    3.查看CPU,内存,类,线程运行信息

      

    4.查看线程详情

      

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

    5.抽样器

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

      

    6.监控远程的JVM

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

      6.1 什么是JMX

        JMX(Java Management Extensions,即java管理扩展)是一个为应用程序,设备,系统等植入管理功能的框架爱。JMV可以跨域一系列异构操作系统平台,系统体系结构和网络传输协议,灵活的开发无缝集成的系统,网络和服务器管理应用;

      6.2 监控远程的Tomcat

        想要监控远程的Tomcat,就需要在远程的Tomcat进行对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

        修改完成后,重启Tomcat;

      6.3 使用VisualVM连接远程Tomcat

        添加远程主机:

          

        在一个主机下可能会有很多个JVM需要监控,所以接下来要在该主机上添加需要空间的JVM:

        单击右键添加JMX连接:  

          

          

        连接成功。使用方法和前面就一样了,就可以和监控本地JVM进程一样,监控远程的Tomcat进程;

  • 相关阅读:
    docker架构的详解
    docker的核心原理-cgroup
    网络运维面试题
    100道linux运维笔试题
    运维岗位面试题集合
    python——筛子游戏
    同道前辈
    delphi中使用SocketStream读写数据的技巧
    百度地图API
    HTML中小meta的大作用
  • 原文地址:https://www.cnblogs.com/wnwn/p/12404033.html
Copyright © 2020-2023  润新知