Zabbix对Tomcat的监控

简介: Zabbix通过java gateway 及 JMX  对Tomcat 进行监控,并实现自定义模板的导入及应用,模拟实际生产中的Tomacat性能等参数的图形监测显示。

1. Tomcat 服务器的准备
通过脚本完成Tomcat服务器的准备。

#### 上传相应的软件包和脚本,完成Tomcat的服务器准备
[root@CentOS84-IP78 ]#cd /data/
[root@CentOS84-IP78 ]#ll
total 176372
-rw-r--r-- 1 root root  11915655 Apr  8 20:53 apache-tomcat-10.0.20.tar.gz
-rwxr-xr-x 1 root root      3013 May  9 15:36 install_tomcat2022.sh
-rw-r--r-- 1 root root 168679847 Apr  8 22:27 jdk-11.0.14_linux-x64_bin.tar.gz
[root@CentOS84-IP78 ]#
 
[root@CentOS84-IP78 ]#cat install_tomcat2022.sh

#!/bin/bash
#
#******************************************************************<strong>
#FileName:      install_tomcat.sh
#Description:       The test script
#Copyright (C):     2021 All rights reserved
#</strong>******************************************************************

DIR=`pwd`
JDK_FILE="jdk-11.0.14_linux-x64_bin.tar.gz"
TOMCAT_FILE="apache-tomcat-10.0.20.tar.gz"
JDK_DIR="/usr/local"
TOMCAT_DIR="/usr/local"

color () {
    RES_COL=60
    MOVE_TO_COL="echo -en \\033[${RES_COL}G"
    SETCOLOR_SUCCESS="echo -en \\033[1;32m"
    SETCOLOR_FAILURE="echo -en \\033[1;31m"
    SETCOLOR_WARNING="echo -en \\033[1;33m"
    SETCOLOR_NORMAL="echo -en \E[0m"
    echo -n "$2" && $MOVE_TO_COL
    echo -n "["
    if [ $1 = "success" -o $1 = "0" ] ;then
        ${SETCOLOR_SUCCESS}
        echo -n $"  OK  "    
    elif [ $1 = "failure" -o $1 = "1"  ] ;then
        ${SETCOLOR_FAILURE}
        echo -n $"FAILED"
    else
        ${SETCOLOR_WARNING}
        echo -n $"WARNING"
    fi
    ${SETCOLOR_NORMAL}
    echo -n "]"
    echo                                                                                                                              
}

install_jdk(){
if !  [  -f "$DIR/$JDK_FILE" ];then
    color 1 "$JDK_FILE 文件不存在" 
    exit; 
elif [ -d $JDK_DIR/jdk ];then
    color 1  "JDK 已经安装" 
    exit
else 
    [ -d "$JDK_DIR" ] || mkdir -pv $JDK_DIR
fi
tar xvf $DIR/$JDK_FILE  -C $JDK_DIR
cd  $JDK_DIR && ln -s jdk* jdk 

cat >  /etc/profile.d/jdk.sh <<EOF
export JAVA_HOME=$JDK_DIR/jdk
export JRE_HOME=\$JAVA_HOME/jre
export CLASSPATH=\$JAVA_HOME/lib/:\$JRE_HOME/lib/
export PATH=\$PATH:\$JAVA_HOME/bin
EOF
.  /etc/profile.d/jdk.sh
java -version && color 0 "JDK 安装完成" || { color 1  "JDK 安装失败" ; exit; }

}

install_tomcat(){
if ! [ -f "$DIR/$TOMCAT_FILE" ];then
    color 1 "$TOMCAT_FILE 文件不存在" 
    exit; 
elif [ -d $TOMCAT_DIR/tomcat ];then
    color 1 "TOMCAT 已经安装" 
    exit
else 
    [ -d "$TOMCAT_DIR" ] || mkdir -pv $TOMCAT_DIR
fi
tar xf $DIR/$TOMCAT_FILE -C $TOMCAT_DIR
cd  $TOMCAT_DIR && ln -s apache-tomcat-*/  tomcat
echo "PATH=$TOMCAT_DIR/tomcat/bin:"'$PATH' > /etc/profile.d/tomcat.sh
id tomcat &> /dev/null || useradd -r -s /sbin/nologin tomcat

cat > $TOMCAT_DIR/tomcat/conf/tomcat.conf <<EOF
JAVA_HOME=$JDK_DIR/jdk
EOF

chown -R tomcat.tomcat $TOMCAT_DIR/tomcat/

cat > /lib/systemd/system/tomcat.service  <<EOF
[Unit]
Description=Tomcat
#After=syslog.target network.target remote-fs.target nss-lookup.target
After=syslog.target network.target 

[Service]
Type=forking
EnvironmentFile=$TOMCAT_DIR/tomcat/conf/tomcat.conf
ExecStart=$TOMCAT_DIR/tomcat/bin/startup.sh
ExecStop=$TOMCAT_DIR/tomcat/bin/shutdown.sh
RestartSec=3
PrivateTmp=true
User=tomcat
Group=tomcat

[Install]
WantedBy=multi-user.target
EOF
systemctl daemon-reload
systemctl enable --now tomcat.service &> /dev/null
systemctl is-active tomcat.service &> /dev/null &&  color 0 "TOMCAT 安装完成" || { color 1 "TOMCAT 安装失败" ; exit; }

}
install_jdk 
install_tomcat

[root@CentOS84-IP78 ]#chmod +x install_tomcat2022.sh 
[root@CentOS84-IP78 ]#./install_tomcat2022.sh 
..................
java version "11.0.14" 2022-01-18 LTS
Java(TM) SE Runtime Environment 18.9 (build 11.0.14+8-LTS-263)
Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.14+8-LTS-263, mixed mode)
JDK 安装完成                                               [  OK  ]
TOMCAT 安装完成                                            [  OK  ]
[root@CentOS84-IP78 ]#

#### 通过浏览器访问能看到网页
http://192.168.250.78:8080/

2. 部署java gateway服务器
Java gateway是一个独立于zabbix server和zabbix agent的组件,java gateway可以是单独一台服务器,也可以和zabbix server或者zabbix agent共用一台服务器,注意区分端口不冲突即可。本次使用一台单独的服务器,IP地址为192.168.250.118/24 。

#### 部署java gateway服务器
## 安装yum源及安装zabbix-java-gateway
[root@CentOS84-IP118 ]#rpm -Uvh https://repo.zabbix.com/zabbix/6.0/rhel/8/x86_64/zabbix-release-6.0-1.el8.noarch.rpm
[root@CentOS84-IP118 ]#dnf -y install zabbix-java-gateway

## 修改并配置zabbix_java_gateway.conf
[root@CentOS84-IP118 ]#vim /etc/zabbix/zabbix_java_gateway.conf
[root@CentOS84-IP118 ]#grep "^[a-Z]" /etc/zabbix/zabbix_java_gateway.conf
LISTEN_IP="0.0.0.0"
LISTEN_PORT=10052
PID_FILE="/var/run/zabbix/zabbix_java_gateway.pid"
START_POLLERS=8
TIMEOUT=30
[root@CentOS84-IP118 ]#

## 启动并设定开机自启
[root@CentOS84-IP118 ]#systemctl restart zabbix-java-gateway
[root@CentOS84-IP118 ]#systemctl enable zabbix-java-gateway

## 验证安装
[root@CentOS84-IP118 ]#lsof -i:10052
COMMAND   PID   USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
java    37771 zabbix   13u  IPv6  72370      0t0  TCP *:10052 (LISTEN)
[root@CentOS84-IP118 ]#ss -tln | grep 10052
LISTEN 0      50                 *:10052            *:*

3. 配置Zabbix Server调用Java Gateway

#### 配置zabbix server调用java gateway
[root@CentOS84-IP18 ]#vim /etc/zabbix/zabbix_server.conf           
[root@CentOS84-IP18 ]#grep "^[a-Z]" /etc/zabbix/zabbix_server.conf 
LogFile=/var/log/zabbix/zabbix_server.log
LogFileSize=0
PidFile=/run/zabbix/zabbix_server.pid
SocketDir=/run/zabbix
DBHost=192.168.250.38
DBName=zabbix
DBUser=zabbix
DBPassword=shone123456 
DBPort=3306
#### 下面三行就是针对tomcat监控配置的命令行
JavaGateway=192.168.250.118
JavaGatewayPort=10052
StartJavaPollers=20

SNMPTrapperFile=/var/log/snmptrap/snmptrap.log
Timeout=4
LogSlowQueries=3000
StatsAllowedIP=127.0.0.1
[root@CentOS84-IP18 ]#

#### 重启zabbix-server
[root@CentOS84-IP18 ]#systemctl restart zabbix-server

#### 验证Java Pollers
[root@CentOS84-IP18 ]#ps -ef | grep java
#### 见下图

企业微信截图_1652876936194.png

4. Tomcat开启JMX监控
4.1 配置 Tomcat服务器开启JMX监控
JMX在Java编程语言中定义了应用程序以及网络管理和监控的体系结构、设计模式、应用程序接口以及服务,通常使用JMX来监控系统的运行状态。

#### tomcat开启JMX监控:
[root@CentOS84-IP78 ]#vim /usr/local/apache-tomcat-10.0.20/bin/catalina.sh
# 搜索 Execute The Requested Command ,在下方添加以下内容
# ----- Execute The Requested Command -----------------------
CATALINA_OPTS="$CATALINA_OPTS
-Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.port=12345
-Dcom.sun.management.jmxremote.authenticate=false
-Dcom.sun.management.jmxremote.ssl=false
-Djava.rmi.server.hostname=192.168.250.78"
# Bugzilla 37848: only output this if we have a TTY

########################################################################
#### 上面的文件写成五行重启tomcat报错,写成一行就没问题
[root@CentOS84-IP78 ]#systemctl restart tomcat                             
[root@CentOS84-IP78 ]#systemctl status tomcat                             
● tomcat.service - Tomcat
   Loaded: loaded (/usr/lib/systemd/system/tomcat.service; enabled; vendor preset: disabled)
   Active: failed (Result: exit-code) since Mon 2022-05-09 16:52:58 CST; 2s ago
  Process: 3292 ExecStop=/usr/local/tomcat/bin/shutdown.sh (code=exited, status=0/SUCCESS)
  Process: 3324 ExecStart=/usr/local/tomcat/bin/startup.sh (code=exited, status=0/SUCCESS)
 Main PID: 3353 (code=exited, status=127)

May 09 16:52:58 CentOS84-IP78 systemd[1]: Starting Tomcat...
May 09 16:52:58 CentOS84-IP78 systemd[1]: Started Tomcat.
May 09 16:52:58 CentOS84-IP78 systemd[1]: tomcat.service: Main process exited, code=exited, status=127/n/a
May 09 16:52:58 CentOS84-IP78 systemd[1]: tomcat.service: Failed with result 'exit-code'.
[root@CentOS84-IP78 ]#

########################################################################
# ----- Execute The Requested Command -----------------------------------------
CATALINA_OPTS="$CATALINA_OPTS -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=12345 -Dcom.sun.manage
ment.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=192.168.250.78"

# Bugzilla 37848: only output this if we have a TTY

#### 上面的文件写成五行重启tomcat报错,写成一行就没问题,服务可以正常启动
[root@CentOS84-IP78 ]#systemctl restart tomcat                             
[root@CentOS84-IP78 ]#systemctl status tomcat                             
● tomcat.service - Tomcat
   Loaded: loaded (/usr/lib/systemd/system/tomcat.service; enabled; vendor preset: disabled)
   Active: active (running) since Mon 2022-05-09 16:55:02 CST; 3s ago
  Process: 3292 ExecStop=/usr/local/tomcat/bin/shutdown.sh (code=exited, status=0/SUCCESS)
  Process: 3387 ExecStart=/usr/local/tomcat/bin/startup.sh (code=exited, status=0/SUCCESS)
 Main PID: 3395 (java)
    Tasks: 39 (limit: 23544)
   Memory: 118.7M
   CGroup: /system.slice/tomcat.service
           └─3395 /usr/local/jdk/bin/java -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties -D>

May 09 16:55:02 CentOS84-IP78 systemd[1]: Starting Tomcat...
May 09 16:55:02 CentOS84-IP78 systemd[1]: Started Tomcat.

[2]+  Stopped                 systemctl status tomcat
[root@CentOS84-IP78 ]#

[root@CentOS84-IP78 ]#netstat -ant
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State      
tcp        0      0 0.0.0.0:111             0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
tcp        0      0 127.0.0.1:631           0.0.0.0:*               LISTEN     
tcp        0    224 192.168.250.78:22       192.168.250.254:1258    ESTABLISHED
tcp6       0      0 :::32346                :::*                    LISTEN     
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN     
tcp6       0      0 :::111                  :::*                    LISTEN     
tcp6       0      0 :::8080                 :::*                    LISTEN     
tcp6       0      0 :::33556                :::*                    LISTEN     
tcp6       0      0 :::22                   :::*                    LISTEN     
tcp6       0      0 ::1:631                 :::*                    LISTEN     
tcp6       0      0 :::12345                :::*                    LISTEN     
[root@CentOS84-IP78 ]#

4.2 通过jconsole验证JMX数据

## 安装win版本的jdk环境后,在下面的目录可以看到这个可执行文件,运行后出现界面并建立连接。
C:\Program Files\Java\jdk1.8.0_333\bin\jvisualvm

image.png

5. zabbix server添加JMX监控
进入Zabbix-Server 服务器的管理页面进行如下配置
image.png

image.png

image.png

6. 配置Zabbix对Tomcat主机的监控
6.1 对Tomcat主机配置abbix-agent

## 对Tomcat主机配置abbix-agent,实现对主机资源等监控
[root@CentOS84-IP78 ]#ss -tln
State        Recv-Q       Send-Q                  Local Address:Port              Peer Address:Port      Process       
LISTEN       0            128                           0.0.0.0:22                     0.0.0.0:*                       
LISTEN       0            50                                  *:32346                        *:*                       
LISTEN       0            1                  [::ffff:127.0.0.1]:8005                         *:*                       
LISTEN       0            100                                 *:8080                         *:*                       
LISTEN       0            50                                  *:33556                        *:*                       
LISTEN       0            128                              [::]:22                        [::]:*                       
LISTEN       0            50                                  *:12345                        *:*                       
[root@CentOS84-IP78 ]#

[root@CentOS84-IP78 ]#netstat -ant
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State      
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
tcp        0    320 192.168.250.78:22       192.168.250.254:1258    ESTABLISHED
tcp6       0      0 :::32346                :::*                    LISTEN     
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN     
tcp6       0      0 :::8080                 :::*                    LISTEN     
tcp6       0      0 :::33556                :::*                    LISTEN     
tcp6       0      0 :::22                   :::*                    LISTEN     
tcp6       0      0 :::12345                :::*                    LISTEN     
tcp6       0      0 192.168.250.78:32346    192.168.250.250:61221   ESTABLISHED   
tcp6       0      0 192.168.250.78:32346    192.168.250.250:61211   ESTABLISHED
tcp6       0      0 192.168.250.78:12345    192.168.250.250:61209   ESTABLISHED  #jvisualvm的连接
[root@CentOS84-IP78 ]#

## 安装IP78上针对操作系统的监控agent
[root@CentOS84-IP78 ]#rpm -Uvh https://repo.zabbix.com/zabbix/6.0/rhel/8/x86_64/zabbix-release-6.0-1.el8.noarch.rpm
Retrieving https://repo.zabbix.com/zabbix/6.0/rhel/8/x86_64/zabbix-release-6.0-1.el8.noarch.rpm
warning: /var/tmp/rpm-tmp.sCLmF4: Header V4 RSA/SHA512 Signature, key ID a14fe591: NOKEY
Verifying...                          ################################# [100%]
Preparing...                          ################################# [100%]
Updating / installing...
   1:zabbix-release-6.0-1.el8         ################################# [100%]
[root@CentOS84-IP78 ]#dnf clean all
33 files removed
[root@CentOS84-IP78 ]#dnf -y install zabbix-agent 
[root@CentOS84-IP78 ]#systemctl enable --now zabbix-agent


[root@CentOS84-IP78 ]#ss -tln |grep 10050
LISTEN 0      128               0.0.0.0:10050      0.0.0.0:*          
LISTEN 0      128                  [::]:10050         [::]:*          
[root@CentOS84-IP78 ]#grep "^[a-Z]" /etc/zabbix/zabbix_agentd.conf
PidFile=/run/zabbix/zabbix_agentd.pid
LogFile=/var/log/zabbix/zabbix_agentd.log
LogFileSize=0
Server=127.0.0.1
ServerActive=127.0.0.1
Hostname=Zabbix server
Include=/etc/zabbix/zabbix_agentd.d/*.conf
[root@CentOS84-IP78 ]#

## 修改并重新配置好agent的配置文件了
[root@CentOS84-IP78 ]#vim /etc/zabbix/zabbix_agentd.conf
[root@CentOS84-IP78 ]#grep "^[a-Z]" /etc/zabbix/zabbix_agentd.conf
PidFile=/run/zabbix/zabbix_agentd.pid
LogFile=/var/log/zabbix/zabbix_agentd.log
LogFileSize=0
Server=192.168.250.18
ListenPort=10050
ListenIP=0.0.0.0
StartAgents=3
ServerActive=127.0.0.1
Hostname=192.168.250.78
Include=/etc/zabbix/zabbix_agentd.d/*.conf
[root@CentOS84-IP78 ]#

[root@CentOS84-IP78 ]#systemctl restart zabbix-agent                     
[root@CentOS84-IP78 ]#systemctl status zabbix-agent

6.2 在Zabbix上配置对Tomcat主机的资源监控

image.png

image.png

image.png

image.png

image.png

7. Zabbix监控页面展示
image.png

相关文章
|
8月前
|
Arthas 监控 Java
Arthas 可以用于监控和诊断在 Windows 系统下部署的 Tomcat 服务
Arthas 可以用于监控和诊断在 Windows 系统下部署的 Tomcat 服务
887 2
|
8月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
1月前
|
监控 安全 前端开发
使用 Zabbix 监控堆外应用
使用 Zabbix 监控堆外应用
49 9
|
1月前
|
监控 数据可视化 Java
zabbix全面的监控能力
zabbix全面的监控能力
56 7
|
5月前
|
监控 安全 Linux
在Linux中,zabbix如何监控脑裂?
在Linux中,zabbix如何监控脑裂?
|
2月前
|
监控 Java Shell
监控堆外第三方监控工具Zabbix
监控堆外第三方监控工具Zabbix
41 5
|
2月前
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
122 7
|
3月前
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
【10月更文挑战第5天】随着OceanBase社区版的广泛应用,企业纷纷采用这一高性能、高可用的分布式数据库系统。为了确保系统的稳定运行,使用成熟的Zabbix监控工具进行全面监控至关重要。本文通过具体示例介绍了如何配置Zabbix监控OceanBase,包括安装配置、创建监控模板和监控项、编写脚本、设置触发器及图形展示等步骤,帮助读者快速上手,及时发现并解决问题,确保业务始终处于最佳状态。
98 2
|
4月前
|
监控 关系型数据库 MySQL
zabbix agent集成percona监控MySQL的插件实战案例
这篇文章是关于如何使用Percona监控插件集成Zabbix agent来监控MySQL的实战案例。
91 2
zabbix agent集成percona监控MySQL的插件实战案例
|
6月前
|
监控 安全 Java
使用JMX监控Tomcat
【7月更文挑战第18天】