通过Zabbix监控Tomcat单机多实例
作者:@skyflask
转载本文请注明出处:https://www.cnblogs.com/skyflask/p/11231185.html
目录
一、获取多实例
二、采集数据
三、模板制作
四、主机上套
五、查看最新数据
六、参考文档和脚本地址
前面已经介绍过Tomcat单机多实例部署,接下来就在他的基础上进行下一步操作:Tomcat多实例监控!
Tomcat多实例监控过程和之前的redis多实例原理一样,分为以下4步:
1、获取多实例
2、采集数据
3、制作模板
4、主机套模板
一、获取多实例
在前面我们已经知道Tomcat多实例的目录结构如下:
获取多实例之前,需要进行如下设置:
1、在bin目录下的catalina.sh脚本增加如下内容
1 2 3 4 5 6 7 | # ----- Execute The Requested Command ----------------------------------------- CATALINA_OPTS="$CATALINA_OPTS -Djava.rmi.server.hostname=10.11.100.99 -Dcom.sun.management.jmxremote= true -Dcom.sun.management.jmxremote.ssl= false -Dcom.sun.management.jmxremote.authenticate= false " |
注意必须在 “Execute The Requested Command”后面新增,指定主机名或IP,是否开启远程管理,是否启动ssl,是否启用认证。
2、在单独实例中设置(conf/server.xml文件)
1 | <Listener className= "org.apache.catalina.mbeans.JmxRemoteLifecycleListener" rmiRegistryPortPlatform= "12345" rmiServerPortPlatform= "12346" /> |
说明:远程连接端口是12345,获取数据端口是12346
同样地,在ins02中
1 | <Listener className= "org.apache.catalina.mbeans.JmxRemoteLifecycleListener" rmiRegistryPortPlatform= "12347" rmiServerPortPlatform= "12348" /> |
远程连接端口是12347,获取数据端口是12348
3、重启多实例,查看端口启动情况
4、获取多实例端口
cat jmx_discovery.sh
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | #!/bin/bash t_datadir=`find /usr/local/tomcat/tomcat-*/conf/ -name server.xml|awk -F "/conf/server.xml" '{print $1}' ` tomcat_no=`find /usr/local/tomcat/tomcat-*/conf/ -name server.xml|wc -l` n_port=12345 i=1 printf '{"data":[\n' for tomcat in $t_datadir do t_service=$(echo "$tomcat" |awk -F "/" '{print $(NF)}' ) if [ "$i" != ${tomcat_no} ];then printf "\t\t{ \n" printf "\t\t\t\"{#JMX_PORT}\":\"${n_port}\",\n" printf "\t\t\t\"{#JAVA_NAME}\":\"${t_service}\"},\n" else printf "\t\t{ \n" printf "\t\t\t\"{#JMX_PORT}\":\"${n_port}\",\n" printf "\t\t\t\"{#JAVA_NAME}\":\"${t_service}\"}]}\n" fi let "n_port=n_port+2" let "i=i+1" done |
注意,我这里的目录结构需要根据你的部署进行修改!
执行脚本:
发现两个实例。
二、采集数据
数据采集需要使用到cmdline-jmxclient-0.10.3.jar,专门用来通过JMX方式获取数据的。
拷贝cmdline-jmxclient-0.10.3.jar到/lib下,当然你也可以随便放置其他目录,只要zabbix用户能够访问就行,因为zabbix-agent是由zabbix用户启动的。
采集脚本:
cat add_service_tomcat.sh
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | #!/bin/bash local_ip=`ifconfig|awk -F '[ :]+' 'NR==2 {print $4}' ` #提取主机IP cat >> /etc/zabbix/zabbix_agentd.d/tomcat.conf <<END #修改zabbix_agentd.conf,添加KEY UserParameter=java.jmx.discovery[*],/etc/zabbix/externalscripts/jmx_discovery.sh UserParameter=java.Runtime.status[*],java -jar /lib/cmdline-jmxclient-0.10.3.jar - $local_ip:\$1 java.lang:type=Runtime \$2 2>&1 |grep \$2 |awk '{print \$NF}' UserParameter=java.Memory.status[*],java -jar /lib/cmdline-jmxclient-0.10.3.jar - $local_ip:\$1 java.lang:type=Memory \$2 2>&1 |grep \$2 |awk '{print \$NF}' UserParameter=java.System.status[*],java -jar /lib/cmdline-jmxclient-0.10.3.jar - $local_ip:\$1 java.lang:type=OperatingSystem \$2 2>&1 |grep \$2 |awk '{print \$NF}' UserParameter=java.HeapMemoryUsage.status[*],java -jar /lib/cmdline-jmxclient-0.10.3.jar - $local_ip:\$1 java.lang:type=Memory HeapMemoryUsage 2>&1 |grep \$2 |awk '{print \$NF}' UserParameter=java.NonHeapMemoryUsage.status[*],java -jar /lib/cmdline-jmxclient-0.10.3.jar - $local_ip:\$1 java.lang:type=Memory NonHeapMemoryUsage 2>&1 |grep \$2 |awk '{print \$NF}' UserParameter=java.LoadClass.status[*],java -jar /lib/cmdline-jmxclient-0.10.3.jar - $local_ip:\$1 java.lang:type=ClassLoading \$2 2>&1 |awk '{print \$NF}' UserParameter=java.Threading.status[*],java -jar /lib/cmdline-jmxclient-0.10.3.jar - $local_ip:\$1 java.lang:type=Threading \$2 2>&1 |awk '{print \$NF}' END |
三、模板制作
根据采集的数据进行模板制作。
四、主机上套
五、查看最新数据
数据图标
六、参考文档和脚本地址
https://github.com/loveqx/zabbix-doc/tree/master/zabbix-scripts/zabbix-template-tomcat
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」