dthre 发表于 2016-9-9 11:19:59

zabbix使用zabbix-java-gateway监控jvm/tomcat性能

JAVA-GATEWAY Zabbix本身不支持直接监控Java,在zabbix 1.8以前,只能使用Zapcat来做代理监控,而且要修改源代码,非常麻烦。所有后来为了解决这个监控问题,Zabbix和Java双方应运生成了各自的代理监控程序:zabbix 2.0以后添加了服务进程zabbix-java-gateway;Java有了JMX,全称是Java Management Extensions,即Java管理扩展。
双方的工作原理 比如:当Zabbix-Server需要知道java应用程序的某项性能的时候,会启动自身的一个Zabbix-JavaPollers进程去连接Zabbix-JavaGateway请求数据,而ZabbixJavagateway收到请求后使用“JMXmanagementAPI”去查询特定的应用程序,而前提是应用程序这端在开启时需要“-Dcom.sun.management.jmxremote”参数来开启JMX远程查询就行。Java程序会启动自身的一个简单的小程序端口12345向Zabbix-JavaGateway提供请求数据。
开始监控部署
从上面的原理图中我们可以看出,配置Zabbix监控Java应用程序的关键点在于:配置Zabbix-JavaGateway、让Zabbix-Server能够连接Zabbix-JavaGateway、Tomcat开启JVM远程监控功能等
1)环境准备系统环境
1
2
3
4
# cat /etc/redhat-release
CentOS Linux release 7.2.1511 (Core)
# /application/zabbix/sbin/zabbix_server -V
zabbix_server (Zabbix) 3.0.3




特别注意:编译安装zabbix server需要加上--enable-java以支持jmx监控,如果之前的zabbix server没加,那么请重新编译安装,参考编译参数
1
./configure --prefix=/application/zabbix-3.0.3 --enable-server --enable-agent --enable-java --enable-ipv6 --with-mysql=/application/mysql-5.5.49/bin/mysql_config--with-net-snmp --with-libcurl --with-libxml2 --with-openipmi --with-unixodbc --with-openssl




由于要使用到tomcat作为监控示例,所以简单部署一个tomcat环境
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# tar xf jdk-8u73-linux-x64.gz
# tar xf apache-tomcat-8.0.36.tar.gz
# mv jdk1.8.0_73 /application/
# ln -s /application/jdk1.8.0_73/ /application/jdk
# sed -i.ori '$a export JAVA_HOME=/application/jdk\nexport PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH\nexport CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$JAVA_HOME/lib/tools.jar' /etc/profile
# source /etc/profile
# java -version
java version "1.8.0_73"
Java(TM) SE Runtime Environment (build 1.8.0_73-b02)
Java HotSpot(TM) 64-Bit Server VM (build 25.73-b02, mixed mode)
# ln -s /application/apache-tomcat-8.0.36/ tomcat
# echo 'export TOMCAT_HOME=/application/tomcat'>>/etc/profile
# source /etc/profile
# chown -R root.root /application/jdk/ /application/tomcat/
# tail -4 /etc/profile
export JAVA_HOME=/application/jdk
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
export CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$JAVA_HOME/lib/tools.jar
export TOMCAT_HOME=/application/tomcat
# /application/tomcat/bin/startup.sh #开启tomcat
# lsof -i:8080
COMMAND   PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
java    40859 root   47uIPv671038      0t0TCP *:webcache (LISTEN)





2)安装软件
1
yum install -y java java-devel zabbix-java-gateway





3)配置zabbix_java_gateway端口10052
1
2
3
4
5
6
# vim /etc/zabbix/zabbix_java_gateway.conf
#zabbix_java_gateway配置文件里有默认端口等设置,这里我们保持默认即可
# systemctl start zabbix-java-gateway.service
# lsof -i:10052
USER   FD   TYPEDEVICE SIZE/OFF NODE NAME
java    92222 root   11uIPv6 1360516      0t0TCP *:10052 (LISTEN)





4)配置zabbix-server访问gateway

1
2
3
4
# vim /application/zabbix/etc/zabbix_server.conf
JavaGateway=172.16.2.150 #gateway地址
StartJavaPollers=5#预启动进程轮训个数
# systemctl restart zabbix_server.service





5)开启JMX远程监控
1
2
3
4
5
6
7
8
9
10
11
# vim /application/tomcat/bin/catalina.sh #tomcat的远程调用脚本
CATALINA_OPTS="$CATALINA_OPTS -Dcom.sun.management.jmxremote #开启远程监控
-Dcom.sun.management.jmxremote.port=12345 #远程监控端口
-Dcom.sun.management.jmxremote.ssl=false #远程ssl验证为false
-Dcom.sun.management.jmxremote.authenticate=false #关闭权限认证
-Djava.rmi.server.hostname=172.16.2.150" #提供数据的的主机地址(由于我是用的一台机器,所以IP相同,如果是生产环境不同的机器,这个地址是部署了tomcat的主机地址)
# /application/tomcat/bin/shutdown.sh
# /application/tomcat/bin/startup.sh
# lsof -i:12345 #JVM监听端口
COMMAND   PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
java    41062 root   20uIPv672478      0t0TCP *:ddi-tcp-1 (LISTEN)




注意:如果端口起不来,看日志
1
2
3
# tail /application/tomcat/logs/catalina.out

Error: Exception thrown by the agent : java.net.MalformedURLException: Local host name unknown: java.net.UnknownHostException: linux-node1.lichengbing.cn: linux-node1.lichengbing.cn: unknown error




添加主机名解析解决
1
2
# cat /etc/hosts
172.16.2.150 linux-node1.lichengbing.cn





6)此时我们就也可以使用windowsJava工具JConsole测试(提前安装好java)
7)在zabbix中添加主机和模板开始监控Java添加主机模板中添加两个JMX模板


页: [1]
查看完整版本: zabbix使用zabbix-java-gateway监控jvm/tomcat性能