首页 > 其他分享 >JVM监控工具之jvisualvm

JVM监控工具之jvisualvm

时间:2022-12-10 17:36:13浏览次数:50  
标签:management JVM sun Dcom 点击 线程 监控 jvisualvm jmxremote

一、简介

JVisualVM是Netbeans的profile子项目,已在JDK6.0 update 7 中自带(bin/jvisualvm.exe),能够监控线程,内存情况,查看方法的CPU时间和内存中的对象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的)。

二、配置

通过JVisualVM远程连接服务器监控JVM,需要在被监控的服务器上tomcat的启动文件catalina.sh中加入以下配置:

 JAVA_OPTS="-Dcom.sun.management.jmxremote -Djava.rmi.server.hostname=192.168.182.130 -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false" 

JMX的相关参数:

参数名 类型 描述
-Dcom.sun.management.jmxremote 布尔 是否支持远程JMX访问,默认true
-Dcom.sun.management.jmxremote.port 数值 监听端口号,方便远程访问
-Dcom.sun.management.jmxremote.authenticate 布尔 是否需要开启用户认证,默认开启
-Dcom.sun.management.jmxremote.ssl 布尔 是否对连接开启SSL加密,默认开启
-Dcom.sun.management.jmxremote.access.file 路径 对访问用户的权限授权的文件的路径,默认路径JRE_HOME/lib/management/jmxremote.access
-Dcom.sun.management.jmxremote. password.file 路径 设置访问用户的用户名和密码,默认路径JRE_HOME/lib/management/ jmxremote.password

三、连接

四、模块介绍

1、概述

概述界面,主要显示JVM的信息,包括JVM参数以及系统属性等

2、监视

(1)按钮“执行垃圾回收”可通知JVM执行Full GC

(2)按钮“堆Dump”可生成堆内存快照,下面详细讲解堆Dump的使用

2.1、堆dump

  2.1.1、概要

       首先生成堆内存快照

     

        把文件下载到本地后使用JVisualVM打开,如下图:

     

    (1)红框标注的箭头处,可以凭你的点击顺序切换前后窗口

    (2)查询最大的对象,个数可自行定制;

    (3)点击“显示线程”可以显示线程细节,如下所示:

        

      (1)timed_waiting和runnable表示线程运行状态

    (2)daemon表示这个线程是守护线程,如没有标记daemon则表示它是一个用户线程,如main线程

    (3)prio表示该线程的优先级,在java线程中数字越大优先级越高,取值在1至10之间,默认为5

    (4)点击被标注成蓝色的相关类,可以在类实例数界面查看细节

  2.1.2、实例数

  

  (1)右上角的三个按钮可以对界面进行定制

  (2)点击“计算保留大小”可计算每个field的保留尺寸,简言之就是它所占的byte值

  (3)右下角红框处标记出了,不同的图形代表不同的角色

  2.1.3、类

  

  (1)左下角可以通过过滤器来过滤显示视图

  (2)右击某个类可以让其在实例界面显示,查看其细节

  (3)点击右上角红框处可以与另一个内存快照进行比较,在比较视图中可以看出每个类的增加和减少的情况

  2.1.4、QQL控制台

  

  (1)选中具体的Query实例,点击打开,再点击执行就可以进行查询了,保存按钮可以保存你的query语句

  (2)比较实用的是PermGen分析语句

3、线程

(1)线程的颜色从绿、紫、黄、褐、橙,分别代表运行、休眠、等待、驻留和死锁

(2)点击线程Dump即可生成线程快照,其功能跟监视里面堆dump生成的heapdump文件里面的显示线程类似,如下图:

4、抽样器

4.1、抽样器简介:

  (1)通过“设置”可以对CPU的采样来源以及内存的刷新时间进行设置

  (2)点击CPU或者内存即可开始监控,点击Stop则停止采样

4.2、CPU

4.2.1、CPU样例

(1)点击线程Dump可生成线程快照

(2)点击快照可生成线程的快照,快照里面包含了所有线程的调用树以及其热点编译情况,如下图所示:

4.2.2、线程CPU时间

(1)点击增量按钮后,可记录线程的变化,功能有点类似JProfilter的“Mark Current Values”。

4.3、内存

4.3.1、堆柱状图

 功能与前面介绍过的类似

4.3.2、每个线程分配

 功能与前面介绍过的类似

标签:management,JVM,sun,Dcom,点击,线程,监控,jvisualvm,jmxremote
From: https://www.cnblogs.com/wfw001-2018/p/12679644.html

相关文章

  • JVM监控命令大全
    1、jdb(TheJavaDebuger) jdb 用来对core文件和正在运行的Java进程进行实时地调试,里面包含了丰富的命令帮助您进行调试,它的功能和Sunstudio里面所带的dbx非常相似,但......
  • Linux监控命令之top
    一、命令说明top命令能够实时监控系统的运行状态,并且可以按照CPU、内存和执行时间进行排序,同时top命令还可以通过交互式命令进行设定显示,通过top命令可以查看即时活跃......
  • Linux监控命令之iostat
    一、使用说明iostat是对系统的磁盘I/O操作进行监控,它的输出主要显示磁盘读写操作的统计信息,同时给出CPU的使用情况。同vmstat一样,iostat不能对某个进程进行深入分析,......
  • Linux监控命令之sar
    一、使用说明sar是目前Linux上最为全面的系统性能分析工具之一,可以从多方面对系统的活动进行报告,包括:文件的读写情况、系统调用的使用情况、磁盘I/O、CPU效率、内存使......
  • Linux监控命令之lsof
    一、命令说明lsof命令的原始功能是列出打开的文件的进程,但LINUX下,所有的设备都是以文件的行式存在的,所以,lsof的功能很强大。二、参数说明-a:列出打开文件存在的进......
  • JVM参数配置及内存调优
    一、JVM常见参数配置堆内存相关参数参数名称含义默认值 -Xms初始堆大小物理内存的1/64(<1GB)默认(MinHeapFreeRatio参数可以调整)空余堆内存小于40%时,JVM......
  • 自动配料系统控制器PLC如何实现远程监控和维护
    自动配料系统是集成输送、计量、配料、定量、混合等功能于一体的自动化生产线,在建材、化工、冶金、矿山、电力、食品、饲料加工等行业中得到广泛应用。随着行业扩展与科学技......
  • JVM 命令 jps jstat jstack
    jps显示出所有的JAVA进程以及PIDjstat查看堆内存各部分的使用量,以及加载类的数量jstack–用来查看堆栈信息jps-lvmVtop-Hppid将线程转换为16进制,因为堆......
  • 六阶段:第38周 JVM性能调优-实战篇
            使用JMC                        mat软件           ......
  • 六阶段:第37周 JVM性能调优-理论+工具篇 各种调优工具 有用
                                                      ......