zabbix之通過jmx監控tomcat

zabbix監控tomcat

1.編譯zabbix的時候需要添加參數--enable-java

關於如何安裝zabbix,可以參考上一篇文章http://blog.unix178.com/

備份zabbix_server.confzabbix_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監控端口

wKiom1OX8VSTJlwzAAIwcjQz8g0536.jpg

自定義監控項

wKioL1OX8T7ivvQgAAHOISwZbnE164.jpg

查看繪圖結果

wKiom1OX8YWDZQmNAAHhoChPYIQ957.jpg


如果你的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


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章