JVM监控实践:VisualVM监控远程服务SpringBoot

1 缘起

最近学习《深入理解Java虚拟机》,
读完核心内容:第三章,
开始进入监控实践,其中,VisualVM之前没有使用过,
最重要原因是VisualVM可以免费学习和使用,
以VisualVM作为监控工具进行监控实践。
分享内容如下。

2 启动服务

本文使用VisualVM检测远程SpringBoot服务,即
VisualVM与SpringBoot服务不在同一台机器,
因此,SpringBoot服务启动时要开启RMI,
启动样例如下:

java -jar \
-Djava.rmi.server.hostname=192.168.211.129 \
-Dcom.sun.management.jmxremote \
-Dcom.sun.management.jmxremote.port=9122 \
-Dcom.sun.management.jmxremote.ssl=false \
-Dcom.sun.management.jmxremote.authenticate=false \
/home/xindaqi/project/tutorial/tutorial.jar
序号属性描述
1java.rmi.server.hostname运行SpringBoot服务的主机名
2com.sun.management.jmxremote.portjmx端口
3com.sun.management.jmxremote.ssl标识位。是否开启SSL
4com.sun.management.jmxremote.authenticate标识位。是否开启认证

3 启动Visual VM

3.1 安装VisualVM

两种方式:
(1)在Java安装环境中,找到:path/bin/jvisualvm.exe
(2)下载安装VisualVM:官网http://visualvm.github.io/
或者免费下载:https://download.csdn.net/download/Xin_101/85585189
在bin中找到:visualvm.exe
本文采用独立安装的方式启动VisualVM,版本为:2.1.3。

3.2 启动

启动页面如下图所示。
在这里插入图片描述

4 配置

本文使用VisualVM检测远程SpringBoot服务,
因此需要在Remote中操作,测试步骤及结果如下文。

4.1 添加远程主机

在Remote中添加远程主机,即运行SpringBoot服务的机器。
在这里插入图片描述
SpringBoot主机名为:192.168.211.129,配置如下图所示。
在这里插入图片描述

4.2 添加JMX连接

接下来添加JMX连接,获取运行的应用,
配置如下图所示。
在这里插入图片描述
添加具体的应用,格式为:hostname:port,
其中,hostname为SpringBoot的主机名,port为SpringBoot参数中的RMI端口,
配置如下图所示。
在这里插入图片描述

5 监控

5.2 控制面板

完成连接后,接下来打开控制面板,
如下图所示。
在这里插入图片描述

5.3 监控属性

控制面板首页监控的属性有:Monitor、Threads和Sampler,如下图所示。

在这里插入图片描述

序号属性描述
1Monitor监控CPU使用率、堆使用率、类数量和线程数量
2Threads监控线程状态:Running、Sleeping、Wait、Park和Monitor
3Sampler监控CPU和内存占用

5.3.1 Monitor

Monitor监控的信息有CPU使用率、堆使用率、类数量和线程数量,
监控指标如下图所示。

在这里插入图片描述

5.3.2 Threads

Threads监控线程状态:Running、Sleeping、Wait、Park和Monitor,
监控信息如下图所示。
在这里插入图片描述

5.3.3 Sampler

Sampler监控CPU和内存占用,对CPU和内存使用进行采样,
采样信息如下图所示。
在这里插入图片描述

  • CPU使用采样
    CPU采样包括总体使用采样和线程使用采样,总体使用采样如下图所示。
    在这里插入图片描述
    线程使用CPU采样如下图所示。
    在这里插入图片描述
    RMI线程使用CPU如下图所示。
    在这里插入图片描述

  • 内存使用采样
    内存使用如下图所示,包括对象类型、存活的类和存活的对象内存使用。
    在这里插入图片描述

6 小结

要点:
(1)Monitor:监控CPU使用率、堆使用率、类数量和线程数量;
(2)Threads:监控线程状态:Running、Sleeping、Wait、Park和Monitor;
(3)Sampler:监控CPU和内存占用;
(4)VisualVM两种启动方式:使用JDK内置的VisualVM或者使用独立下载的VisualVM。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天然玩家

坚持才能做到极致

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值