分布式JVM监控工具
2022年5月24日大约 2 分钟约 684 字
分布式 JVM 监控工具
介绍
该项目为了方便开发者更快监控多个远程主机 jvm,如果你的项目是 Spring boot 那么很方便集成,jar 包引入即可,不是 Spring boot 也不用气馁,你可以快速自行初始化一个 Spirng boot 程序引入 jar 包即可
效果展示
data:image/s3,"s3://crabby-images/c84c2/c84c2d2f1f8e5d19c25d3910356206b78beac608" alt="分布式JVM监控工具"
整体架构
data:image/s3,"s3://crabby-images/72416/724163d66c5297ef4130081233979fae46ad4e43" alt="分布式JVM监控工具"
git 地址
https://github.com/xk4848123/monitorhttps://github.com/xk4848123/monitor-server
使用前提
需要机器中有 JDK,不仅仅是 JRE,配置好 java path,程序中依靠 ExcuteCmd 找寻 jdk 基本命令
手把手教你用
克隆 monitor-server
git clone https://github.com/xk4848123/monitor-server.git
data:image/s3,"s3://crabby-images/e4b7f/e4b7f2c37f87f784a42c309b0d5ae0802f7ba1be" alt="分布式JVM监控工具"
idea -> Project from Existing Sources……
data:image/s3,"s3://crabby-images/18e2e/18e2ef851c701279f8ccea435fa7c23482e26366" alt="分布式JVM监控工具"
选中项目 pom.xml
data:image/s3,"s3://crabby-images/b53c6/b53c660aef4339cdb70c4cb1c0986886b1f25eb5" alt="分布式JVM监控工具"
修改 resources/application.properties
data:image/s3,"s3://crabby-images/29996/29996770f82a27469464471ab489e1ad4e1666d6" alt="分布式JVM监控工具"
monitor.serve[0].name=serve-1
monitor.serve[0].address=http://127.0.0.1:8081/monitor(这里需要与客户端的monitor.path对应)
monitor.serve[1].name=serve-2
monitor.serve[1].address=http://127.0.0.1:8082(同上)
....
12345
这里可以配置多个监控主机,格式注意下
address=http://ip:port/xxx(xxx是你在monitor上配置的,下文中会有)
name=server-1(每个monitor不同即可,便于显示时区分)
run monitor-server
有异常没关系,我们把监控客户端也部起来就好了
说在前面
一个操作系统内部署一个监控客户端就好,当你有个多个 jvm 程序时,只要有一个部署就可以监控
下载 Release
https://github.com/xk4848123/monitor
data:image/s3,"s3://crabby-images/26101/26101ff9a597720f61e940e856554f84a4731ff7" alt="分布式JVM监控工具"
进入 Release 列表,下载 jar
data:image/s3,"s3://crabby-images/9d1f0/9d1f050b8f9247025ef36c542b0e53ebeb60c987" alt="分布式JVM监控工具"
本地 mvn install(等到博主把 jar 传到中心仓库就不用这么么麻烦了)
cmd 执行以下命令
mvn install:install-file -DgroupId=com.github.xk4848123 -DartifactId=monitor-spring-boot-starter -Dversion=2.3.1 -Dpackaging=jar -Dfile=C:\Users\Administrator\Downloads\monitor-spring-boot-starter.jar
data:image/s3,"s3://crabby-images/5c719/5c719793e0e46226cd93150cd53af951af46d8e3" alt="分布式JVM监控工具"
在任意一个 Spring boot 项目中使用,我这里打开我本地一个叫 chat 的项目
data:image/s3,"s3://crabby-images/eaf4a/eaf4a84dbf05f28509fb4d15e027c9cfa3eae6ec" alt="分布式JVM监控工具"
在 resources/application.properties 增加属性
#决定访问路径,可以自行定义
monitor.path=monitor
#决定是否启动监控客户端
monitor.enable=true
1234
data:image/s3,"s3://crabby-images/56590/56590c44ea2842ca168c2268218a9213ff611e4c" alt="分布式JVM监控工具"
pom.xml 引入
data:image/s3,"s3://crabby-images/7a735/7a73592f8c209fa6e7c92aba1d1ceb5865fb0965" alt="分布式JVM监控工具"
跑起项目
OK!
我们现在访问 monitor-server(我当下部署的在http://127.0.0.1:8888,大家根据自己的配置访问)
data:image/s3,"s3://crabby-images/6f0f2/6f0f201a8f99dd244ef9e3670780942461f1aa5b" alt="分布式JVM监控工具"