【运维知识进阶篇】Zabbix5.0稳定版详解8(Zabbix监控Java项目+详解JMX与Zabbix-Java-Gateway原理+详解监控Java项目流程原理)

简介: 【运维知识进阶篇】Zabbix5.0稳定版详解8(Zabbix监控Java项目+详解JMX与Zabbix-Java-Gateway原理+详解监控Java项目流程原理)

本篇文章给大家介绍用Zabbix监控Java项目,在监控Java项目的时候,我们可以通过JMX和Java Gateway两种监控方式。

JMX是一种用于监视和管理Java应用程序的标准API,允许你收集应用程序的运行时信息,如内存使用情况、线程状态、CPU负载等,并且还可以通过JMX远程连接进行配置和管理。你可以使用JMX客户端来连接到运行JMX的Java应用程序,以收集信息和执行管理操作。

Java Gateway则是使用JMX技术来远程管理和监控分布式Java应用程序的代理。它位于Java应用程序和JMX客户端之间,充当中间件,将JMX请求转发到Java应用程序中的相应MBean,并返回结果给JMX客户端。Java Gateway可以处理与多个Java应用程序的连接,从而提供集中的监控和管理接口。

我们在10.0.0.71部署zabbix服务端,在10.0.0.7部署zabbix-java-gateway,同时在10.0.0.7部署tomcat进行监控测试。

一、安装Tomcat服务并开启JMX协议和取值页面

1、安装JDK与Tomcat

1. # 安装JDK
2. [root@Web01 ~]# rpm -ivh jdk-8u181-linux-x64.rpm
3. [root@Web01 ~]# java -version
4. java version "1.8.0_181"
5. Java(TM) SE Runtime Environment (build 1.8.0_181-b13)
6. Java HotSpot(TM) 64-Bit Server VM (build 25.181-b13, mixed mode)
7. 
8. # 安装Tomcat
9. [root@Web01 ~]# wget https://dlcdn.apache.org/tomcat/tomcat-9/v9.0.76/bin/apache-tomcat-9.0.76.tar.gz --no-check-certificate
10. [root@Web01 ~]# tar xf apache-tomcat-9.0.76.tar.gz -C /usr/local/
11. [root@Web01 ~]# ln -s /usr/local/apache-tomcat-9.0.76 /usr/local/tomcat

2、开启JMX协议

1. # 搜索CATALINA_OPTS定位到eval定义这个变量的位置
2. # 在它定义的后面添加如下内容,有个else判断,所以需要添加两处
3. -Dcom.sun.management.jmxremote \
4. -Djava.rmi.server.hostname=172.16.1.7 \    # hostname为本机的IP
5. -Dcom.sun.management.jmxremote.port=12345 \
6. -Dcom.sun.management.jmxremote.ssl=false \
7. -Dcom.sun.management.jmxremote.authenticate=false \

3、启动tomcat

启动并查看JMX协议

1. [root@Web01 ~]# /usr/local/tomcat/bin/startup.sh 
2. [root@Web01 ~]# ss -ntl | grep 12345
3. LISTEN     0      50        [::]:12345                 [::]:*

二、安装并启动zabbix-java-gateway

1. [root@Web01 ~]# yum -y install zabbix-java-gateway
2. [root@Web01 ~]# systemctl enable --now zabbix-java-gateway.service
3. [root@Web01 ~]# netstat -tnulp|grep 10052
4. tcp6       0      0 :::10052                :::*                    LISTEN      95299/java

三、配置服务端连接Java-gateway

1. [root@Zabbix ~]# cat /etc/zabbix/zabbix_server.conf
2. ...
3. JavaGateway=172.16.1.7
4. ...
5. JavaGatewayPort=10052
6. ...
7. StartJavaPollers=3
8. [root@Zabbix ~]# systemctl restart zabbix-server.service

四、通过JMX进行监控

删除原主机后通过JMX再次添加主机

可以链接官网提供的tomcat的模板

可以监控到数据

五、监控Java项目流程原理详解

Zabbix Java Gateway是一个独立的Java应用程序,用于与Zabbix服务器进行通信,并代理与Java应用程序的JMX接口交互。Zabbix服务器通过与Java Gateway通信来获取Java应用程序的监控数据。

由于我们的Zabbix-Java-Gateway和要监控的Tomcat部署在了同一台主机,所以效果不明显,我这边简单说下,其实我们的zabbix服务端在配置文件中配置了Zabbix-Java-Gateway的主机,所以在监控JMX接口的服务的时候,都是通过Zabbix-Java-Gateway的主机去监控,相当于把Zabbix-Java-Gateway的主机变成了中间件,当Zabbix的监控接口传递给Zabbix-Java-Gateway后,Zabbix-Java-Gateway再去寻找这个接口(IP和端口),寻找到这个接口后再通过JMX去采集Tomcat所需要监控的数据;

这是因为zabbix是c语言写的,web端是php,不能直接与java进行通信,所以需要Zabbix-Java-Gateway这个中间件去做请求转发;

我们将Zabbix-Java-Gateway和要监控的Tomcat部署在了同一台主机了,其实完全可以部署在不同主机哈,我这边就是图省事儿,这个逻辑有点类似于分布式监控,分布式监控其实也是用的中间件Proxy;

六、只使用JMX不使用Zabbix-Java-Gateway的尝试

满足大家的好奇心,我们测试一下只使用JMX不使用Zabbix-Java-Gateway

1、关闭Zabbix-Java-Gateway服务,zabbix服务端配置文件也取消调用,重启服务

1. [root@Web01 ~]# systemctl stop zabbix-java-gateway.service 
2. 
3. [root@Zabbix ~]# cat /etc/zabbix/zabbix_server.conf
4. ...
5. # JavaGateway=172.16.1.7
6. ...
7. # JavaGatewayPort=10052
8. ...
9. # StartJavaPollers=3
10. [root@Zabbix ~]# systemctl restart zabbix-server.service

2、取消添加的主机重新添加

发现一直监控不到数据


我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!

目录
相关文章
|
19天前
|
安全 Java 程序员
《从头开始学java,一天一个知识点》之:控制流程:if-else条件语句实战
**你是否也经历过这些崩溃瞬间?** - 看了三天教程,连`i++`和`++i`的区别都说不清 - 面试时被追问"`a==b`和`equals()`的区别",大脑突然空白 - 写出的代码总是莫名报NPE,却不知道问题出在哪个运算符 这个系列为你打造Java「速效救心丸」!每天1分钟,地铁通勤、午休间隙即可完成学习。直击高频考点和实际开发中的「坑位」,拒绝冗长概念,每篇都有可运行的代码示例。明日预告:《for与while循环的使用场景》。 ---
54 19
|
12天前
|
消息中间件 运维 监控
智能运维,由你定义:SAE自定义日志与监控解决方案
SAE(Serverless应用引擎)是阿里云推出的全托管PaaS平台,致力于简化微服务应用开发与管理。为满足用户对可观测性和运维能力的更高需求,SAE引入Sidecar容器技术,实现日志采集、监控指标收集等功能扩展,且无需修改主应用代码。通过共享资源模式和独立资源模式,SAE平衡了资源灵活性与隔离性。同时,提供全链路运维能力,确保应用稳定性。未来,SAE将持续优化,支持更多场景,助力用户高效用云。
|
1月前
|
存储 缓存 监控
|
2月前
|
监控 运维
HTTPS 证书自动化运维:https证书管理系统- 自动化监控
本文介绍如何设置和查看域名或证书监控。步骤1:根据证书状态选择新增域名或证书监控,线上部署推荐域名监控,未部署选择证书监控。步骤2:查询监控记录详情。步骤3:在详情页查看每日定时检测结果或手动测试。
HTTPS 证书自动化运维:https证书管理系统- 自动化监控
|
2月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
68 23
|
2月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
65 22
|
2月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
81 25
|
3月前
|
Prometheus 运维 监控
Prometheus+Grafana+NodeExporter:构建出色的Linux监控解决方案,让你的运维更轻松
本文介绍如何使用 Prometheus + Grafana + Node Exporter 搭建 Linux 主机监控系统。Prometheus 负责收集和存储指标数据,Grafana 用于可视化展示,Node Exporter 则采集主机的性能数据。通过 Docker 容器化部署,简化安装配置过程。完成安装后,配置 Prometheus 抓取节点数据,并在 Grafana 中添加数据源及导入仪表盘模板,实现对 Linux 主机的全面监控。整个过程简单易行,帮助运维人员轻松掌握系统状态。
442 3
|
5月前
|
运维 Linux Apache
,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具
【10月更文挑战第7天】随着云计算和容器化技术的发展,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具,通过定义资源状态和关系,确保系统始终处于期望配置状态。本文介绍Puppet的基本概念、安装配置及使用示例,帮助读者快速掌握Puppet,实现高效自动化运维。
120 4
|
2月前
|
Linux 持续交付 调度
HTTPS 证书自动化运维:https证书管理系统-自动化部署
本指南介绍如何部署Linux服务器节点。首先复制生成的Linux脚本命令,然后将其粘贴到目标服务器上运行。接着刷新页面查看节点记录,并点击“配置证书”选择证书以自动部署。最后,节点部署完成,后续将自动调度,无需人工干预。
HTTPS 证书自动化运维:https证书管理系统-自动化部署

热门文章

最新文章

推荐镜像

更多