【运维知识进阶篇】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年运维经验,持续分享运维干货,感谢大家的阅读和关注!

目录
相关文章
|
21天前
|
Java 调度
Java并发编程:深入理解线程池的原理与实践
【4月更文挑战第6天】本文将深入探讨Java并发编程中的重要概念——线程池。我们将从线程池的基本原理入手,逐步解析其工作过程,以及如何在实际开发中合理使用线程池以提高程序性能。同时,我们还将关注线程池的一些高级特性,如自定义线程工厂、拒绝策略等,以帮助读者更好地掌握线程池的使用技巧。
|
Java 数据安全/隐私保护
java实现加密电话号码,有具体的加密流程注释
java实现加密电话号码,有具体的加密流程注释
21 0
|
1月前
|
SQL Java 应用服务中间件
Java项目防止SQL注入的四种方案
Java项目防止SQL注入的四种方案
41 0
|
1月前
|
开发框架 Java API
java反射机制的原理与简单使用
java反射机制的原理与简单使用
17 1
|
28天前
|
缓存 Java C#
【JVM故障问题排查心得】「Java技术体系方向」Java虚拟机内存优化之虚拟机参数调优原理介绍(一)
【JVM故障问题排查心得】「Java技术体系方向」Java虚拟机内存优化之虚拟机参数调优原理介绍
79 0
|
1月前
|
Java
软件工程设计原理里氏替换原则 ,具体实现及JAVA代码举例
里氏替换原则(Liskov Substitution Principle, LSP)是面向对象设计的基本原则之一,由Barbara Liskov提出。这个原则指出,如果类 S 是类 T 的子类型,则程序中使用 T 的对象的地方都可以不经修改地使用 S 的对象。换句话说,子类的对象应该能够替换掉它们的父类对象,而不影响程序的正确性。这个原则强调了继承关系中的行为兼容性,保证了基类和派生类之间的正确抽象和继承关系。
24 3
|
1月前
|
人工智能 监控 算法
java智慧城管源码 AI视频智能分析 可直接上项目
Java智慧城管源码实现AI视频智能分析,适用于直接部署项目。系统运用互联网、大数据、云计算和AI提升城市管理水平,采用“一级监督、二级指挥、四级联动”模式。功能涵盖AI智能检测(如占道广告、垃圾处理等)、执法办案、视频分析、统计分析及队伍管理等多个模块,利用深度学习优化城市管理自动化和智能化,提供决策支持。
223 4
java智慧城管源码 AI视频智能分析 可直接上项目
|
2天前
|
搜索推荐 前端开发 Java
java医院绩效考核管理系统项目源码
系统需要和his系统进行对接,按照设定周期,从his系统获取医院科室和医生、护士、其他人员工作量,对没有录入信息化系统的工作量,绩效考核系统设有手工录入功能(可以批量导入),对获取的数据系统按照设定的公式进行汇算,且设置审核机制,可以退回修正,系统功能强大,完全模拟医院实际绩效核算过程,且每步核算都可以进行调整和参数设置,能适应医院多种绩效核算方式。
4 0
|
3天前
|
前端开发 Java 测试技术
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
|
3天前
|
Java
Java基础知识整理,驼峰规则、流程控制、自增自减
在这一篇文章中我们总结了包括注释、关键字、运算符的Java基础知识点,今天继续来聊一聊命名规则(驼峰)、流程控制、自增自减。
34 3

推荐镜像

更多