zabbix项目实践(代码片段)

cash-su cash-su     2023-02-04     748

关键词:

一,Zabbix生产环境监测案例概述

1.1 项目规划

  • [x] :主机分组
    • 交换机
    • Nginx
    • Tomcat
    • MySQL
    • Apache
    • PHP-fpm
    • redis(也有状态页, 自己研究)
    • memcache(也有状态页, 自己研究)
  • [x] :监控对象识别:
    • 使用SNMP监控交换
    • 使用IPMI监控服务器硬件
    • 使用Agent监控服务器
    • 使用JMX监控JAVA
    • 监控MySQL
    • 监控Web状态
    • 监控Nginx状态
    • 监控Apache状态
    • 监控Tomcat状态

1.2 SNMP监控流程

  1. 交换机上开启snmp
  2. 在zabbix上添加监控(设置SNMP interfaces)
  3. 关联监控模版

1.3 IPMI

建议使用自定义item监控服务器硬件,在本地执行ipmitool命令来获取数据

可以在本地执行ipmitool命令获取数据(命令需要安装)

1.4 JMX(使用Zabbix Java Gateway代理)

用来获取java数据,本次的实战内容

1.5 实战监控Nginx,Apache,MySQL,PHP-fpm

今天的实战内容,请 注意总结过程

1.6 Zabbix的Web监测

今天的实战内容,请 注意总结过程

二,Zabbix监控MySQL数据库操作实战

我们需要部署一个MySQL服务和一个zabbix-agentd客户端

2.1 编写监控脚本

在nginx服务器(192.168.0.221)上安装一个MySQL
下面是监控mysql状态的一个shell脚本,内容如下:

[[email protected] scripts]# pwd
/server/scripts
[[email protected] scripts]# cat check_mysql.sh 
#!/bin/bash
# author:Mr.chen

MySQL_USER="root"
MySQL_PWD="123123"
MySQL_HOST="127.0.0.1"
MySQL_PORT="3306"

MySQL_CONN="/usr/local/mysql/bin/mysqladmin -u$MySQL_USER -h$MySQL_HOST -P$MySQL_PORT -p$MySQL_PWD"

if [ $# -ne "1" ];then
    echo "arg error!"
fi

case $1 in
    Uptime)
        result=`$MySQL_CONN status | cut -f2 -d":" | cut -f1 -d "T"`
        echo $result
        ;;
    Com_update)
        result=`$MySQL_CONN extended-status | grep -w "Com_update" | cut -d"|" -f3`
        echo $result
        ;;
    Slow_querles)
        result=`$MySQL_CONN status | cut -f5 -d":" | cut -f1 -d"O"`
        echo $result
        ;;
    Com_select)
        result=`$MySQL_CONN extended-status | grep -w "Com_select" | cut -d "|" -f3`
        echo $result
        ;;
    Com_rollback)
        result=`$MySQL_CONN extended-status | grep -w "Com_rollback" | cut -d"|" -f3`
        echo $result
        ;;
    Questions)
        result=`$MySQL_CONN status | cut -f4 -d":" | cut -f1 -d"S"`
        echo $result
        ;;
    Com_insert)
        result=`$MySQL_CONN extended-status | grep -w "Com_insert" | cut -d"|" -f3`
        echo $result
        ;;
    Com_delete)
        result=`$MySQL_CONN extended-status | grep -w "Com_delete" | cut -d"|" -f3`
        echo $result
        ;;
    Com_commit)
        result=`$MySQL_CONN extended-status | grep -w "Com_commit" | cut -d"|" -f3`
        echo $result
        ;;
    Bytes_sent)
        result=`$MySQL_CONN extended-status | grep -w "Bytes_sent" | cut -d"|" -f3`
        echo $result
        ;;
    Bytes_received)
        result=`$MySQL_CONN extended-status | grep -w "Bytes_received" | cut -d"|" -f3`
        echo $result
        ;;
    Com_begin)
        result=`$MySQL_CONN extended-status | grep -w "Com_begin" | cut -d"|" -f3`
        echo $result
        ;;
    *)
        echo "Usage:$0(Uptime|Com_update|Slow_querles|Com_rollback|Questions|Com_insert|Com_delete|Com_commit|Bytes_sent|Bytes_received|Com_begin)"
        ;;
esac

2.2 在zabbix-agent端创建自定义键值配置文件

#创建mysql.status的键值
[[email protected] scripts]# chmod +x check_mysql.sh 
[[email protected] scripts]# chown zabbix.zabbix check_mysql.sh
[[email protected] zabbix]# cd /etc/zabbix/zabbix_agentd.d/
[[email protected] zabbix_agentd.d]# cat mysql_status.conf 
UserParameter=mysql.status[*],/server/scripts/check_mysql.sh $1

#删除旧键值模版
[[email protected] zabbix_agentd.d]# rm -rf userparameter_mysql.conf 

#创建mysql.ping和mysql.version的键值
[[email protected] zabbix_agentd.d]# cat mysql_status.conf 
UserParameter=mysql.status[*],/server/scripts/check_mysql.sh $1
UserParameter=mysql.ping,/usr/local/mysql/bin/mysqladmin -uroot -p123123 ping | grep -c alive
UserParameter=mysql.version,/usr/local/bin/mysql -V

#重启zabbix-agentd服务
[[email protected] zabbix_agentd.d]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [  OK  ]
Starting Zabbix agent:                                     [  OK  ]

2.3 在zabbix-server端测试键值

[[email protected]_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Uptime]"
2791
[[email protected]_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Com_commit]"
0
[[email protected]_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Bytes_sent]"
144628
[[email protected]_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Bytes_received]"
3934
[[email protected]_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.ping"
1
[[email protected]_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.version"
/usr/local/bin/mysql  Ver 14.14 Distrib 5.5.32, for linux2.6 (x86_64) using readline 5.1

2.4 在zabbix-server端Web前台引入zabbix监控MySQL的模版

zabbix自带监控MySQL的模版,我们只需要将模版引入到主机即可
配置-->主机-->选择主机-->模板,然后将MySQL模版连接到此主机即可

技术分享图片

技术分享图片

技术分享图片

技术分享图片

技术分享图片

从图中可以发现模版里的键值都是我们之前已经定义好了的键值。

三,Zabbix监控Apache、Nginx操作实战

3.1 实战监控Apache

3.1.1 源码编译构建apache服务

#为了避免冲突,若系统中已经安装httpd服务,务必删除
[[email protected] ~]# rpm -q httpd
package httpd is not installed
[[email protected] ~]# /etc/init.d/iptables stop
[[email protected] ~]# setenforce 0
setenforce: SELinux is disabled

#源码构建apache
[[email protected] httpd-2.2.17]# tar xf httpd-2.2.17.tar.gz -C /usr/src/
[[email protected] httpd-2.2.17]# cd /usr/src/httpd-2.2.17/
[[email protected] httpd-2.2.17]# ./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi && make && make install
[[email protected] httpd-2.2.17]# cd /usr/local/httpd/
[[email protected] httpd]# ls
bin  build  cgi-bin  conf  error  htdocs  icons  include  lib  logs  man  manual  modules
[[email protected] httpd]# ln -s /usr/local/httpd/bin/* /usr/local/bin/
[[email protected] httpd]# cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd
[[email protected] httpd]# chmod +x /etc/init.d/httpd
[[email protected] ~]# cd /usr/local/httpd/htdocs/
[[email protected] htdocs]# echo "`hostname -I` I am apache" > index.html
[[email protected] htdocs]# cat index.html 
192.168.0.222  I am apache
[[email protected] conf]# awk ‘/#ServerName/print NR,$0‘ httpd.conf 
97 #ServerName www.example.com:80
[[email protected] conf]# sed -i -e ‘97 s/#//;s/example/yunjisuan/‘ httpd.conf 
[[email protected] conf]# sed -n ‘97p‘ httpd.conf 
ServerName www.yunjisuan.com:80
[[email protected] conf]# /etc/init.d/httpd start
[[email protected] conf]# netstat -antup | grep httpd
tcp        0      0 :::80                       :::*                        LISTEN      53288/httpd         
[[email protected] conf]# echo "`hostname -I` www.yunjisuan.com" >> /etc/hosts
[[email protected] conf]# tail -1 /etc/hosts
192.168.0.222  www.yunjisuan.com
[[email protected] conf]# curl www.yunjisuan.com
192.168.0.222  I am apache

3.1.2 开启apache状态页

要打开apache的ServerStatus页面,需要在httpd.conf文件最下边加入代码段

ExtendedStatus On
<location /server-status>
SetHandler server-status
Order Deny,Allow
Deny from all
Allow from 127.0.0.1
</location>

最后,重启动apache即可

3.1.3 下载apache zabbix模版并解压

#从如下地址下载apache zabbix模版:
[[email protected] ~]# wget https://github.com/lorf/zapache/archive/master.zip
#解压zip格式压缩文件
[[email protected] ~]# unzip master
[[email protected] ~]# ls -d zapache-master
zapache-master
[[email protected] ~]# cd zapache-master/
[[email protected] ~]# tree zapache-master/
zapache-master/
├── httpd-server-status.conf.sample
├── README.md
├── userparameter_zapache.conf.sample
├── zapache
├── zapache-template-active.xml
└── zapache-template.xml

0 directories, 6 files
  • 此模版文件中包含了监控apache的脚本文件,zabbix的apache模版文件,还有客户端zabbix自定义传key文件。
  • 首先将zapache放到需要监控的apache服务器上的/etc/zabbix/scripts目录下,如果没有scripts目录,自行创建一个即可。然后执行授权:
[[email protected] zapache-master]# chmod 755 /etc/zabbix/scripts/zapache
[[email protected] scripts]# cd /etc/zabbix/scripts/
[[email protected] scripts]# ./zapache 
zapache version: 1.5
usage:
  ./zapache [<url>] TotalAccesses                 - Check total accesses.
  ./zapache [<url>] TotalKBytes                   - Check total KBytes.
  ./zapache [<url>] CPULoad                       - Check CPU load.
  ./zapache [<url>] Uptime                        - Check uptime.
  ./zapache [<url>] ReqPerSec                     - Check requests per second.
  ./zapache [<url>] BytesPerSec                   - Check Bytes per second.
  ./zapache [<url>] BytesPerReq                   - Check Bytes per request.
  ./zapache [<url>] BusyWorkers                   - Check busy workers.
  ./zapache [<url>] IdleWorkers                   - Check idle workers.
  ./zapache [<url>] version                       - Version of this script.
  ./zapache [<url>] ping                          - Check if Apache is up.
  ./zapache [<url>] WaitingForConnection          - Check Waiting for Connection processess.
  ./zapache [<url>] StartingUp                    - Check Starting Up processess.
  ./zapache [<url>] ReadingRequest                - Check Reading Request processess.
  ./zapache [<url>] SendingReply                  - Check Sending Reply processess.
  ./zapache [<url>] KeepAlive                     - Check KeepAlive Processess.
  ./zapache [<url>] DNSLookup                     - Check DNSLookup Processess.
  ./zapache [<url>] ClosingConnection             - Check Closing Connection Processess.
  ./zapache [<url>] Logging                       - Check Logging Processess.
  ./zapache [<url>] GracefullyFinishing           - Check Gracefully Finishing Processess.
  ./zapache [<url>] IdleCleanupOfWorker           - Check Idle Cleanup of Worker Processess.
  ./zapache [<url>] OpenSlotWithNoCurrentProcess  - Check Open Slots with No Current Process.
  • 接着将userparameter_zapache.conf.sample文件放到/etc/zabbix/zabbix_agentd.d目录下,并重命名为userparameter_zapache.conf文件,然后修改键值命令的路径。
  • 最后,重启zabbix-agent服务
[[email protected] zapache-master]# mv userparameter_zapache.conf.sample /etc/zabbix/zabbix_agentd.d/userparameter_zapache.conf
[[email protected] zabbix_agentd.d]# tail -1 userparameter_zapache.conf 
UserParameter=zapache[*],/etc/zabbix/scripts/zapache $1    #本行要修改
[[email protected] zapache-master]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [  OK  ]
Starting Zabbix agent:                                     [  OK  ]

3.1.4 测试键值

#在zabbix-agent端查看脚本用法
[[email protected] zabbix_agentd.d]# cd /etc/zabbix/scripts/
[[email protected] scripts]# ./zapache 
zapache version: 1.5
usage:
  ./zapache [<url>] TotalAccesses                 - Check total accesses.
  ./zapache [<url>] TotalKBytes                   - Check total KBytes.
  ./zapache [<url>] CPULoad                       - Check CPU load.
  ./zapache [<url>] Uptime                        - Check uptime.
  ./zapache [<url>] ReqPerSec                     - Check requests per second.
  ./zapache [<url>] BytesPerSec                   - Check Bytes per second.
  ./zapache [<url>] BytesPerReq                   - Check Bytes per request.
  ./zapache [<url>] BusyWorkers                   - Check busy workers.
  ./zapache [<url>] IdleWorkers                   - Check idle workers.
  ./zapache [<url>] version                       - Version of this script.
  ./zapache [<url>] ping                          - Check if Apache is up.
  ./zapache [<url>] WaitingForConnection          - Check Waiting for Connection processess.
  ./zapache [<url>] StartingUp                    - Check Starting Up processess.
  ./zapache [<url>] ReadingRequest                - Check Reading Request processess.
  ./zapache [<url>] SendingReply                  - Check Sending Reply processess.
  ./zapache [<url>] KeepAlive                     - Check KeepAlive Processess.
  ./zapache [<url>] DNSLookup                     - Check DNSLookup Processess.
  ./zapache [<url>] ClosingConnection             - Check Closing Connection Processess.
  ./zapache [<url>] Logging                       - Check Logging Processess.
  ./zapache [<url>] GracefullyFinishing           - Check Gracefully Finishing Processess.
  ./zapache [<url>] IdleCleanupOfWorker           - Check Idle Cleanup of Worker Processess.
  ./zapache [<url>] OpenSlotWithNoCurrentProcess  - Check Open Slots with No Current Process.

我们发现脚本需要传递两个参数,即url和选项
然后我们在zabbix-server端进行键值测试

[[email protected]_Server scripts]# zabbix_get -s 192.168.0.222 -p 10050 -k "zapache[127.0.0.1 TotalAccesses]"
9
[[email protected]_Server scripts]# zabbix_get -s 192.168.0.222 -p 10050 -k "zapache[www.yunjisuan.com version]"
1.5
[[email protected]_Server scripts]# zabbix_get -s 192.168.0.222 -p 10050 -k "zapache[www.yunjisuan.com ping]"
1

3.1.5 在zabbix-server的Web页面上监控apache

(1)创建一个监控apache的主机

技术分享图片

技术分享图片

(2)导入带有apache监控项的模版

zabbix默认并没有监控apache的监控项模版。我们需要将它导入到apache中。在之前解压出来的目录中,有待导入的web模版

[[email protected] ~]# tree zapache-master/
zapache-master/
├── httpd-server-status.conf.sample
├── README.md
├── zapache-template-active.xml #Web模版
└── zapache-template.xml    #Web模版

0 directories, 4 files

我们将这两个.xml后缀的拷贝到windows上,然后从Web界面导入进去

技术分享图片

技术分享图片

导入以后Web端就有监控apache的监控项模版了

(3)将模版链接到apache主机

技术分享图片

技术分享图片

技术分享图片

3.2 实战监控nginx

3.2.1 开启nginx状态页

#在nginx的配置文件中,添加status配置
location = /nginx-status 
    stub_status on;
    access_log  off;
    allow 127.0.0.1;
    allow 192.168.0.220;    #zabbix服务器地址一般是内网地址
    deny all;

3.2.2 访问设置好的nginx-status链接

#在zabbix-server上通过如下方式获取nginx状态页面信息:
[email protected]_Server ~]# curl 192.168.0.221/nginx-status
Active connections: 1 
server accepts handled requests
 634 634 618 
Reading: 0 Writing: 1 Waiting: 0 

nginx status详细说明如下:
Active connections:对后端发起的活动连接数;
accepts:nginx总共处理了多少个连接;
handled:nginx成功创建了几次握手;
requests:nginx总共处理了多少请求。
Reading:nginx读取客户端的header数;
Writing:nginx返回给客户端的header数;
Waiting:nginx请求处理完成,正在等待下一请求指令的连接

3.2.3 编写nginx状态监控脚本

#下面是nginx状态监控抓取脚本,内容如下:
[[email protected] scripts]# cat nginx_status.sh 
#!/bin/bash
# Set Variables

HOST="127.0.0.1"
PORT="80"

#Functions to return nginx stats

function active()
    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | grep "Active" | awk ‘print $NF‘


function reading()

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | grep "Reading" | awk ‘print $2‘


function writing()

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | grep "Writing" | awk ‘print $4‘


function accepts()

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | awk ‘NR==3‘ | awk ‘print $1‘



function handled()

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | awk ‘NR==3‘ | awk ‘print $2‘


function requests()

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | awk ‘NR==3‘ | awk ‘print $3‘


function ping()

    /sbin/pidof nginx | wc -l


# Run the requested function

$1

3.2.4 给脚本可执行权限并且授权

[[email protected] scripts]# chmod +x nginx_status.sh 
[[email protected] scripts]# chown zabbix.zabbix nginx_status.sh

3.2.5 在zabbix-agent端配置nginx键值配置文件

[[email protected] zabbix_agentd.d]# pwd
/etc/zabbix/zabbix_agentd.d
[[email protected] zabbix_agentd.d]# cat nginx.conf 
UserParameter=nginx.active,/usr/bin/curl -s "http://127.0.0.1:80/nginx-status" | grep "Active" | awk ‘print $NF‘
UserParameter=nginx.status[*],/etc/zabbix/scripts/nginx_status.sh $1
#重启agent客户端
[[email protected] zabbix_agentd.d]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [  OK  ]
Starting Zabbix agent:                                     [  OK  ]

3.2.6 在zabbix-server端测试键值

[[email protected]_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[reading]" -p 10050
0
[[email protected]_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[active]" -p 10050
1
[[email protected]_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[reading]" -p 10050
0
[[email protected]_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[writing]" -p 10050
1
[[email protected]_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[ping]" -p 10050
1

3.2.7 接下来我们需要在Web端导入nginx监控模版

技术分享图片

技术分享图片

技术分享图片

技术分享图片

3.2.8 异常调试

如果Zabbix图形界面一直没有获取到数据,可以通过在zabbix server上执行zabbix_get手动测试:
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.221 -p 10050 -k "nginx.status[active]"
如果获取数据有问题,会给出相应提示,如果能够获取到数据,那就没问题了。

四,Zabbix监控Tomcat操作实战

zabbix监控tomcat,需要zabbix_server开启java poller,zabbix_java开启javaGateway,端口10052,Tomcat JMX开启12345端口,提供性能数据。

数据获取流程为:java poller<-->javaGateway:10052<-->Tomcat:12345

技术分享图片

4.1 配置Tomcat JMX

#配置jmx,在需要监控的tomcat服务器上,编辑catalina.sh,加入如下配置
[[email protected] bin]# sed -n ‘249p‘ /usr/local/tomcat/bin/catalina.sh 
CATALINA_OPTS="-server -Xms256m -Xmx512m -XX:PermSize=64M -XX:MaxPermSize=128m -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=192.168.0.224 -Dcom.sun.management.jmxremote.port=12345"

这里需要注意,必须增加-Djava.rmi.server.hostname选项,并且后面的IP就是tomcat服务器的IP

4.2 重启Tomcat

[[email protected] bin]# /usr/local/tomcat/bin/shutdown.sh 
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/jdk
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
[[email protected] ~]# netstat -antup | grep java
[[email protected] bin]# /usr/local/tomcat/bin/startup.sh 
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/jdk
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
[[email protected] zabbix]# netstat -antup | grep java
tcp        0      0 :::54031                    :::*                        LISTEN      1521/java           
tcp        0      0 :::8080                     :::*                        LISTEN      1521/java           
tcp        0      0 :::53881                    :::*                        LISTEN      1521/java           
tcp        0      0 :::12345                    :::*                      LISTEN      1521/java          #新增端口 
tcp        0      0 ::ffff:127.0.0.1:8005       :::*                        LISTEN      1521/java           
tcp        0      0 :::8009                     :::*                        LISTEN      1521/java       

4.3 编译zabbix,加入java支持

在zabbix server服务器上,编译安装zabbix-server,需要加上--enable-java,以支持jmx监控,如果之前的zabbix server没加此选项,那么需要重新编译安装,编译参数如下:

./configure --prefix=/usr/local/zabbix --with-mysql --with-net-snmp --with-libcurl --enable-server --enable-agent --enable-proxy --enable-java --with-libxml2

特别提示:
在启用--enable-java编译zabbix之前,zabbix server服务器上需要安装JDK,并需要设置JAVA_HOME,以让系统能够识别到jdk的路径

4.3.1 在zabbix-server端安装JDK

#解压jdk
[[email protected]_Server ~]# tar xf jdk-8u60-linux-x64.tar.gz -C /usr/local/
[[email protected]_Server ~]# ln -s /usr/local/jdk1.8.0_60/ /usr/local/jdk
#配置java环境变量
[[email protected]_Server ~]# sed -i.ori ‘$a export JAVA_HOME=/usr/local/jdk
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
export CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar‘ /etc/profile
[[email protected]_Server ~]# tail -3 /etc/profile
export JAVA_HOME=/usr/local/jdk
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
export CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
#让环境变量立刻生效
[[email protected]_Server ~]# source /etc/profile
#检查java环境变量情况
[[email protected]_Server ~]# which java
/usr/local/jdk/bin/java
[[email protected]_Server ~]# java -version
java version "1.8.0_60"
Java(TM) SE Runtime Environment (build 1.8.0_60-b27)
Java HotSpot(TM) 64-Bit Server VM (build 25.60-b23, mixed mode)

4.3.2 重新编译zabbix-server服务器端

#重新编译zabbix-server服务器端之前
[[email protected]_Server ~]# ll /usr/local/zabbix/sbin/
total 8604
-rwxr-xr-x 1 root root 1165774 Jan 20 15:16 zabbix_agentd
-rwxr-xr-x 1 root root 3672055 Jan 20 15:16 zabbix_proxy
-rwxr-xr-x 1 root root 3966037 Jan 20 15:16 zabbix_server

#开始重新编译zabbix-server服务器端
[[email protected]_Server ~]# 
[[email protected]ix_Server ~]# /etc/init.d/zabbix_server stop
Shutting down zabbix_server:                               [  OK  ]
[[email protected]_Server ~]# cd /usr/src/zabbix-3.2.4/
[[email protected]_Server zabbix-3.2.4]# ./configure --prefix=/usr/local/zabbix --with-mysql --with-net-snmp --with-libcurl --enable-server --enable-agent --enable-proxy --enable-java --with-libxml2
[[email protected]_Server zabbix-3.2.4]# make && make install

#重新编译zabbix-server服务器端之后
[[email protected]_Server zabbix-3.2.4]# cd /usr/local/zabbix/sbin/
[[email protected]_Server sbin]# ll
total 8608
-rwxr-xr-x 1 root root 1165774 Jan 25 22:22 zabbix_agentd
drwxr-xr-x 4 root root    4096 Jan 25 22:22 zabbix_java     #多了一个目录
-rwxr-xr-x 1 root root 3672055 Jan 25 22:22 zabbix_proxy
-rwxr-xr-x 1 root root 3966037 Jan 25 22:22 zabbix_server
[[email protected]_Server sbin]# cd zabbix_java/
[[email protected]_Server zabbix_java]# ll
total 20
drwxr-xr-x 2 root root 4096 Jan 25 22:22 bin
drwxr-xr-x 2 root root 4096 Jan 25 22:22 lib
-rw-r--r-- 1 root root  791 Jan 25 22:22 settings.sh    #java gateway配置脚本
-rwxr-xr-x 1 root root  545 Jan 25 22:22 shutdown.sh    #停止java gateway服务
-rwxr-xr-x 1 root root 2025 Jan 25 22:22 startup.sh     #启动java gateway服务

提示:
java gateway服务的配置脚本settings.sh不需要修改任何配置。

4.3.3 启动java Gateway服务

[[email protected]_Server zabbix_java]# /usr/local/zabbix/sbin/zabbix_java/startup.sh 
[[email protected]_Server zabbix_java]# netstat -antup | grep 10052
tcp        0      0 :::10052                    :::*                        LISTEN      13126/java 

4.4 修改zabbix server 配置

默认的情况下,zabbix server未启用javaPollers,需要修改zabbix_server.conf的如下配置

[[email protected]_Server zabbix]# cd /usr/local/zabbix/etc/

#修改以下配置文件的内容
[[email protected]_Server etc]# cat -n zabbix_server.conf | sed -n ‘215p;223p;231p‘
   215  # JavaGateway=
   223  # JavaGatewayPort=10052
   231  # StartJavaPollers=0

#将上述配置文件内容修改成如下
[[email protected]_Server etc]# cat -n zabbix_server.conf | sed -n ‘215p;223p;231p‘
   215  JavaGateway=127.0.0.1   #JavaGateway的地址
   223  JavaGatewayPort=10052
   231  StartJavaPollers=5

#查看已经打开的java poller进程
[[email protected]_Server ~]# ps -ef | grep "java poller" | grep -v grep
zabbix    13233  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #1 [got 0 values in 0.000001 sec, idle 5 sec]
zabbix    13234  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #2 [got 0 values in 0.000015 sec, idle 5 sec]
zabbix    13235  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #3 [got 0 values in 0.000001 sec, idle 5 sec]
zabbix    13236  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #4 [got 0 values in 0.000001 sec, idle 5 sec]
zabbix    13237  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #5 [got 0 values in 0.000001 sec, idle 5 sec]

4.5 重启zabbix_server服务

[[email protected]_Server ~]# /etc/init.d/zabbix_server start
Starting zabbix_server:                                    [  OK  ]
[[email protected]_Server ~]# netstat -antup | grep 10051
tcp        0      0 0.0.0.0:10051               0.0.0.0:*                   LISTEN      13172/zabbix_server 
tcp        0      0 192.168.0.220:10051         192.168.0.221:56752         TIME_WAIT   -                   
tcp        0      0 192.168.0.220:10051         192.168.0.221:56754         TIME_WAIT   -                   
tcp        0      0 192.168.0.220:10051         192.168.0.221:56751         TIME_WAIT   -                   
tcp        0      0 192.168.0.220:10051         192.168.0.220:47162         TIME_WAIT   -           

4.6 Zabbix图形界面配置

4.6.1 创建一个主机利用JMX接口监控tomcat被监控端

技术分享图片

技术分享图片

4.6.2 导入zabbix监控tomcat的模版

因为Zabbix自带的Tomcat模版有兼容性问题,并不好用,因此,我们导入自己制作的监控项模版

技术分享图片

技术分享图片

技术分享图片

技术分享图片

最后我们关联模版即可。

技术分享图片

五,Zabbix监控PHP-FPM操作实战

php-fpm和nginx一样内建了一个状态页,对于想了解php-fpm的状态以及监控php-fpm非常有帮助

5.1 启用php-fpm状态功能

修改php-fpm配置文件,确保如下配置是打开状态:
pm.status_path = /status,具体操作如下

#在Zabbix-server端操作如下
[[email protected]_Server etc]# pwd
/usr/local/php/etc
[[email protected]_Server etc]# ls
pear.conf  php-fpm.conf  php-fpm.conf.default  php.ini
[[email protected]_Server etc]# sed -n ‘360p‘ php-fpm.conf
;pm.status_path = /status
[[email protected]_Server etc]# vim php-fpm.conf +360
[[email protected]_Server etc]# sed -n ‘360p‘ php-fpm.conf
pm.status_path = /status

#重启php-fpm服务
[[email protected]_Server ~]# netstat -antup | grep php-fpm
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      1145/php-fpm
[[email protected]_Server ~]# pkill php-fpm
[[email protected]_Server ~]# netstat -antup | grep 9000
[[email protected]_Server ~]# /usr/local/php/sbin/php-fpm 
[[email protected]_Server ~]# netstat -antup | grep php-fpm
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      18918/php-fpm

5.2 nginx配置php-fpm状态页面

在nginx配置文件nginx.conf里配置php状态页,操作如下

[[email protected]_Server ~]# cd /usr/local/nginx/
[[email protected]_Server nginx]# ls
client_body_temp  conf  fastcgi_temp  html  logs  proxy_temp  sbin  scgi_temp  uwsgi_temp
#配置php-fpm状态页面
[[email protected]_Server nginx]# vim conf/nginx.conf
[[email protected]_Server nginx]# cat conf/nginx.conf
worker_processes  1;
events 
    worker_connections  1024;

http 
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server 
        listen       80;
        server_name  localhost;
        location / 
            root   html;
            index  index.php index.html index.htm;
        
        location = /nginx-status 
            stub_status on;
            access_log off;
        
        location = /status          #添加此location
            include fastcgi_params;
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
        
        location ~ .php$ 
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include fastcgi_params;
        
    

#重启动nginx服务
[[email protected]_Server nginx]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[[email protected]_Server nginx]# /usr/local/nginx/sbin/nginx -s reload

5.3 状态页浏览器访问测试

php-fpm状态页比较个性化的一个地方是它可以带参数,可以带的参数有json、xml、html,使用zabbix或者nagios监控可以考虑使用xml或者默认方式。

技术分享图片

#具体含义说明如下
[[email protected]_Server nginx]# curl 127.0.0.1/status
pool:                 www           #fpm进程池名称,大多数为www
process manager:      dynamic       #进程管理方式(static,dynamic or nodemand.dynamic)
start time:           26/Jan/2018:02:56:58 -0500    #启动日期
start since:          2972          #运行时长
accepted conn:        517           #当前FPM进程池接受的请求数
listen queue:         0             #请求等待队列,如果值不是0,那么要增加FPM的进程数
max listen queue:     4             #请求等待队列最高的数量
listen queue len:     128           #socket等待队列长度
idle processes:       2             #空闲进程数量
active processes:     1             #活跃进程数量
total processes:      3             #总进程数量
max active processes: 3             #最大的活跃进程数量(FPM启动开始算)
max children reached: 0             #达到最大子进程的次数,如果值不为0,那么需要调高最大进程数
slow requests:        0             #当启用了php-fpm的slow-log功能时,如果出现php-fpm慢请求这个计数器会增加,一般不当的MySQL查询会触发这个值

其他状态参数显示形式的数据(json,xml,html)

#以xml的格式输出PHP-fpm状态页
[[email protected]_Server nginx]# curl 127.0.0.1/status?xml
<?xml version="1.0" ?>
<status>
<pool>www</pool>
<process-manager>dynamic</process-manager>
<start-time>1516953418</start-time>
<start-since>3731</start-since>
<accepted-conn>647</accepted-conn>
<listen-queue>0</listen-queue>
<max-listen-queue>4</max-listen-queue>
<listen-queue-len>128</listen-queue-len>
<idle-processes>2</idle-processes>
<active-processes>1</active-processes>
<total-processes>3</total-processes>
<max-active-processes>3</max-active-processes>
<max-children-reached>0</max-children-reached>
<slow-requests>0</slow-requests>

#以json的格式输出PHP-fpm的状态页
</status>[[email protected]_Server nginx]# curl 127.0.0.1/status?json
"pool":"www","process manager":"dynamic","start time":1516953418,"start since":3736,"accepted conn":648,"listen queue":0,"max listen queue":4,"listen queue len":128,"idle processes":2,"active processes":1,"total processes":3,"max active processes":3,"max children reached":0,"slow requests":0[[email protected]_Server nginx]# 

#以html的格式输出PHP-fpm的状态页
[[email protected]_Server nginx]# curl 127.0.0.1/status?html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head><title>PHP-FPM Status Page</title></head>
<body>
<table>
<tr><th>pool</th><td>www</td></tr>
<tr><th>process manager</th><td>dynamic</td></tr>
<tr><th>start time</th><td>26/Jan/2018:02:56:58 -0500</td></tr>
<tr><th>start since</th><td>3748</td></tr>
<tr><th>accepted conn</th><td>650</td></tr>
<tr><th>listen queue</th><td>0</td></tr>
<tr><th>max listen queue</th><td>4</td></tr>
<tr><th>listen queue len</th><td>128</td></tr>
<tr><th>idle processes</th><td>2</td></tr>
<tr><th>active processes</th><td>1</td></tr>
<tr><th>total processes</th><td>3</td></tr>
<tr><th>max active processes</th><td>3</td></tr>
<tr><th>max children reached</th><td>0</td></tr>
<tr><th>slow requests</th><td>0</td></tr>
</table>
</body></html>

5.4 在Zabbix agent端修改配置

在创建Zabbix的agent端键值配置文件的时候,我们可以考虑利用PHP-fpm状态页的不同输出格式来抓取数据。例如我们利用xml格式获取数据,操作如下:

#查看xml格式PHP-fpm状态页数据
[email protected]_Server nginx]# curl 127.0.0.1/status?xml
<?xml version="1.0" ?>
<status>
<pool>www</pool>
<process-manager>dynamic</process-manager>
<start-time>1516953418</start-time>
<start-since>3731</start-since>
<accepted-conn>647</accepted-conn>
<listen-queue>0</listen-queue>
<max-listen-queue>4</max-listen-queue>
<listen-queue-len>128</listen-queue-len>
<idle-processes>2</idle-processes>
<active-processes>1</active-processes>
<total-processes>3</total-processes>
<max-active-processes>3</max-active-processes>
<max-children-reached>0</max-children-reached>
<slow-requests>0</slow-requests>

#创建zabbix监控的agent端键值配置文件
[[email protected]_Server ~]# cd /etc/zabbix/zabbix_agentd.d/
[[email protected]_Server zabbix_agentd.d]# cat userparameter_php-fpm.conf 
UserParameter=php-fpm.status[*],/usr/bin/curl -s "http://127.0.0.1/status?xml" | grep "<$1>" | awk -F "[>|<]" ‘print $$3‘    #这里需要注意在脚本里如果写成$3的话,脚本会认识是一个变量,因此我们需要用$$3

#重启动agent客户端
[[email protected]Zabbix_Server ~]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [  OK  ]
Starting Zabbix agent:                                     [  OK  ]

5.5 进行键值配置文件测试

[[email protected]_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "php-fpm.status[process-manager]"
dynamic
[[email protected]_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "php-fpm.status[start-since]"
5634
[[email protected]_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "php-fpm.status[active-processes]"
1

5.6 Zabbix图形界面导入我们的监控模版

技术分享图片

技术分享图片

六,Zabbix的Web监测功能

Zabbix的Web监测功能,没有任何依赖,不需要agent端,全部依赖于Server的主动监测

利用Web监测,监测Server端的nginx首页

技术分享图片

技术分享图片

技术分享图片

技术分享图片

技术分享图片

技术分享图片

技术分享图片

到这里Web监测我们就创建好了,最后再看一下监控结果

技术分享图片









zabbix6.0安装教程:zabbix6.0安装最佳实践(代码片段)

zabbix6.0安装教程(二):Zabbix6.0安装最佳实践目录概述一、Accesscontrol1.Zabbixagent的安全用户2.UTF-8编码二、ZabbixSecurityAdvisoriesandCVEdatabase1.为Zabbix前端设置SSL三、Webserverhardening1.在URL的根目录上启用Zabbix2.在Web 查看详情

zabbix6.0安装教程:zabbix6.0安装最佳实践(代码片段)

zabbix6.0安装教程(二):Zabbix6.0安装最佳实践目录概述一、Accesscontrol1.Zabbixagent的安全用户2.UTF-8编码二、ZabbixSecurityAdvisoriesandCVEdatabase1.为Zabbix前端设置SSL三、Webserverhardening1.在URL的根目录上启用Zabbix2.在Web 查看详情

zabbix最佳实践一:zabbixserver的安装与配置(代码片段)

...前了解一下(以下内容摘自官方网站)。1.1几个概念架构Zabbix由几个主要的功能组件组成,其职责如下所示。ServerZabbixserver是Zabbixagent向其报告可用性、系统完整性信息和统计信息的核心组件。是存储所有配置信息、统计信息和... 查看详情

zabbix6.0安装教程:zabbix6.0安装最佳实践(代码片段)

zabbix6.0安装教程(二):Zabbix6.0安装最佳实践目录概述一、Accesscontrol1.Zabbixagent的安全用户2.UTF-8编码二、ZabbixSecurityAdvisoriesandCVEdatabase1.为Zabbix前端设置SSL三、Webserverhardening1.在URL的根目录上启用Zabbix2.在Web服务器上启... 查看详情

云原生-zabbix6监控mysql最佳实践(代码片段)

📢📢📢📣📣📣哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10年DBA工作经验一位上进心十足的【大数据领域博主】!😜😜😜中国DBA联盟(ACDU)成员,目前从 查看详情

zabbix6通过odbc方式监控oracle19c最佳实践(代码片段)

📢📢📢📣📣📣哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10年DBA工作经验一位上进心十足的【大数据领域博主】!😜😜😜中国DBA联盟(ACDU)成员,目前从 查看详情

添加自定义监控项目,zabbix配置告警-添加邮箱,zabbix配置告警-添加用户,测试告警(代码片段)

...项目需求:监控某台web的80端口连接数,并出图两步:1)zabbix监控中心创建监控项目;2)针对该监控项目以图形展现(个人觉得是1、写脚本获取并发连接数,2、在服务器获取数字,3.在监控中心创建监控项目,4、针对该监控项... 查看详情

zabbix的架构配置选项(代码片段)

[toc]Zabbix的架构配置选项(二)一、添加自定义监控项目Zabbix的特色:我们有时候会根据业务需求配置一些个性化的需求服务去监控某台web的80端口连接数,并整出监控状态图:[]zabbix监控中心创建监控项目;[]针对该监控项目以图... 查看详情

zabbix的配置和使用(代码片段)

...项目需求:监控某台web的80端口连接数,并出图两步:1)zabbix监控中心创建监控项目;2)针对该监控项目以图形展现1、客户端定义脚本[[email protected]~]#vim/usr/local/sbin/estab.sh//创建脚本,添加以下内容#!/bin/bash##获取80端口并发... 查看详情

67.zabbix添加自定义监控项目配置邮件告警测试告警(代码片段)

...项目需求:监控某台web的80端口连接数,并出图两步:1)zabbix监控中心创建监控项目;2)针对该监控项目以图形展现对于第一步,需要到客户端定义脚本vim/usr/local/sbin/estab.sh//内容如下#!/bin/bash##获取80端口并发连接数netstat-ant|gre... 查看详情

javamikwok实践项目(代码片段)

查看详情

zabbix(代码片段)

19.1Linux监控平台介绍cacti、nagios、zabbix、smokeping、open-falcon等等cacti、smokeping偏向于基础监控,成图非常漂亮cacti、nagios、zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,... 查看详情

zabbix6(代码片段)

...板,在模板中定义出:items,trigger,graph;(选做)项目规划:zabbix-server端:172.16.1 查看详情

zabbix--钉钉告警(代码片段)

zabbix钉钉告警机制群机器人是钉钉群的高级扩展功能,群机器人可以将第三方服务的信息聚合到群聊中,实现自动化的信息同步。例如:通过聚合GitHub,GitLab等源码管理服务,实现源码更新同步;通过聚合Trello,JIRA等项目协调... 查看详情

世纪证券zabbix监控系统升级高可用架构的实践分享(代码片段)

...后台架构有丰富实践经验。世纪证券于2022年8月初完成了Zabbix监控系统的版本(5.2->6.0)和架构升级。本次升级最重要的变更是利用Zabbix6.0官方提供的原生高可用HA特性实现了服务端架构上的高可用。主备机房所有设备的监控已平... 查看详情

zabbix自定义key监控docker(代码片段)

...况。二、想法编写监控脚本,使用自定义key的方式添加到Zabbix中。三、实践1、编写服务监控脚本#!/bin/bashinterval_time=600service_port_file=/script/tmp/service_port.txt#Gener_service_p 查看详情

zabbix配置邮件告警(代码片段)

...项目需求:如果需要监控业务中一些比较复杂的数据,而zabbix不可能给提供这种监控项,那么就需要自己写出监控数据的脚本或者其他语言的程序来获取这个监控值,然后通过zabbix_agentd发送给zabbix_server端处理编辑一个获取数据... 查看详情

ssm项目实践(代码片段)

 码云地址:https://gitee.com/xmr123/JAVAEE/tree/feature-SSM一、项目创建:1、创建一个Javaweb项目并且配置好tomcat等(之前做过此步省略) 2、在setting中引入MAVEN    注意:MAVEN的版本不能早于编辑器的版本否则会报错... 查看详情