zabbix
監控tomcat
1.編譯zabbix的時候需要添加參數--enable-java
關於如何安裝zabbix
,可以參考上一篇文章http://blog.unix178.com/
備份zabbix_server.conf
和zabbix_agentd.conf
文件,重新編譯安裝zabbix
[root@nginx zabbix-2.2.0]# ./configure --enable-server --enable-agent --with-mysql --enable-ipv6 --with-net-snmp --with-libcurl --with-ssh2 --enable-java
2.zabbix_server端安裝jdk
安裝jdk
[root@nginx tmp]# tar xf jdk-7u9-linux-x64.tar.gz -C /usr/local/ [root@nginx tmp]# ls /usr/local/jdk1.7.0_09/ bin jre README.html THIRDPARTYLICENSEREADME.txt COPYRIGHT lib release db LICENSE src.zip include man THIRDPARTYLICENSEREADME-JAVAFX.txt
3.修改zabbix_java相關選項
然後進入到下面的目錄下面進行seeting.sh
腳本編輯
[root@nginx zabbix-2.2.0]# find / -name zabbix_java /usr/local/sbin/zabbix_java /tmp/zabbix-2.2.0/src/zabbix_java [root@nginx zabbix-2.2.0]# [root@nginx zabbix-2.2.0]# ls bin lib settings.sh shutdown.sh startup.sh
該文件默認全部註釋的,啓用下面幾項即可
[root@nginx zabbix_java]# vim settings.sh [root@nginx zabbix_java]# sed -e '/^#/d;/^$/d' settings.sh LISTEN_IP="0.0.0.0" LISTEN_PORT=10052 PID_FILE="/tmp/zabbix_java.pid" START_POLLERS=5 [root@nginx zabbix_java]#
4.修改zabbix_server文件
啓用其中的幾項
[root@nginx zabbix_java]# sed -e '/^#/d;/^$/d' /usr/local/etc/zabbix_server.conf LogFile=/tmp/zabbix_server.log DBName=zabbix DBUser=zabbix DBPassword=zabbix [root@nginx zabbix_java]# vim /usr/local/etc/zabbix_server.conf [root@nginx zabbix_java]# sed -e '/^#/d;/^$/d' /usr/local/etc/zabbix_server.conf LogFile=/tmp/zabbix_server.log DBName=zabbix DBUser=zabbix DBPassword=zabbix JavaGateway=127.0.0.1 JavaGatewayPort=10052 StartJavaPollers=5
5.啓動zabbix_java
找到zabbix_java
目錄路徑,然後執行命令./startup.sh
[root@nginx zabbix-2.2.0]# find / -name zabbix_java /usr/local/sbin/zabbix_java /tmp/zabbix-2.2.0/src/zabbix_java [root@nginx zabbix-2.2.0]# [root@nginx zabbix-2.2.0]# ls bin lib settings.sh shutdown.sh startup.sh [root@nginx zabbix-2.2.0]# ss -tunlp | grep 10052 tcp LISTEN 0 50 :::10052 :::* users:(("java",16405,12))
6.調整tomcat
端,安裝catalina-jmx-remote.jar
下載來安裝:
root@tomcat5 tmp]# wget http://archive.apache.org/dist/tomcat/tomcat-7/v7.0.8/bin/extras/catalina-jmx-remote.jar
將下載好的文件存放到tomcat
子目錄目錄lib
錄下
[root@tomcat5 tmp]# mv catalina-jmx-remote.jar /usr/local/tomcat/lib/ [root@tomcat5 tmp]#
7.修改catalina.sh
文件
修改catalina.sh文件,添加
CATALINA_OPTS="-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.port=12345 -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=172.17.8.24"
8.重啓啓動tomcat
服務和zabbix_agentd
服務
echo "172.17.8.24 Tomcat008024" >>/etc/rc.local #tomcat會解析hostname,否則tomcat啓動失敗
9.服務器端測試是否能正常獲取信息
[root@nginx zabbix-2.2.0]# java -jar /root/cmdline-jmxclient-0.10.3.jar - 192.168.146.130:9999 java.lang:type=Memory NonHeapMemoryUsage 05/24/2014 15:42:02 +0800 org.archive.jmx.Client NonHeapMemoryUsage: committed: 47316992 init: 24313856 max: 136314880 used: 47012784
10.服務器端自定義監控項
添加jmx監控端口
自定義監控項
查看繪圖結果
直接上圖,自己看吧
添加jmx監控端口
自定義監控項
查看繪圖結果
如果你的tomcat端沒有打開iptables或者允許全部端口,按照如上方式沒問題。
-A INPUT -m state --state NEW -m tcp -p tcp --dport 12345:65535 -j ACCEPT
如果開啓了防火牆,按照以上辦法只允許12345沒有作用,tomcat分爲數據端口和連接端口,數據端口是動態的。所以按照以下操作:
http://tomcat.apache.org/download-70.cgi
cd /usr/local/tomcat/bin [按照tomcat版本選擇jar]
wget http://apache.dataguru.cn/tomcat/tomcat-7/v7.0.65/bin/extras/catalina-jmx-remote.jar
chown tomcat:tomcat catalina-jmx-remote.jar
修改Tomcat安裝目錄conf子目錄下的server.xml配置文件:
省略...<Server port="8005" shutdown="SHUTDOWN">
<Listener className="org.apache.catalina.mbeans.JmxRemoteLifecycleListener" rmiRegistryPortPlatform="12345" rmiServerPortPlatform="12346" />
修改Tomcat安裝目錄bin子目錄下的之前的腳本文件setenv.sh:
CATALINA_OPTS="${CATALINA_OPTS} -Djava.rmi.server.hostname=172.17.8.24"CATALINA_OPTS="${CATALINA_OPTS} -Djavax.management.builder.initial="CATALINA_OPTS="${CATALINA_OPTS} -Dcom.sun.management.jmxremote=true"#CATALINA_OPTS="${CATALINA_OPTS} -Dcom.sun.management.jmxremote.port=12345"#端口配置不用了CATALINA_OPTS="${CATALINA_OPTS} -Dcom.sun.management.jmxremote.ssl=false"CATALINA_OPTS="${CATALINA_OPTS} -Dcom.sun.management.jmxremote.authenticate=false"
修改/etc/sysconfig/iptables 防火牆策略:
-A INPUT -m state --state NEW -m tcp -p tcp --dport 12345 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 12346 -j ACCEPT
service iptables restart