zabbix监控Nginx/Tomcat/MySQL的详细教程

zabbix监控Nginx

A机器:zabbix服务端(192.168.234.128) B机器:zabbix客户端(192.168.234.125)

创新互联公司从2013年成立,先为北海等服务建站,北海等地企业,进行企业商务咨询服务。为北海企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

在B机器(zabbix客户端)操作:

编辑nginx虚拟主机配置文件:

[root@centos ~]# vi /etc/nginx/conf.d/default.conf 

在server{}中添加以下内容:

 location /nginx_status
 {
  stub_status on;
  access_log off;
  allow 127.0.0.1;
  deny all;
 }

重载nginx配置:

[root@centos ~]# nginx -s reload

测试:

[root@centos ~]# curl http://127.0.0.1/nginx_status
Active connections: 1 
server accepts handled requests
 3 3 3 
Reading: 0 Writing: 1 Waiting: 0 

#nginx状态信息已显示

状态说明:

zabbix监控Nginx/Tomcat/MySQL的详细教程

添加监控脚本:

vi /usr/local/sbin/ngx_status.sh

添加以下内容:

#!/bin/bash
url="http://127.0.0.1/nginx_status"
curl=/usr/bin/curl

# 检测nginx进程是否存在
function ping {
 /sbin/pidof nginx | wc -l 
}
# 检测nginx性能
function active {
 $curl $url 2>/dev/null| grep 'Active' | awk '{print $NF}'
}
function reading {
 $curl $url 2>/dev/null| grep 'Reading' | awk '{print $2}'
}
function writing {
 $curl $url 2>/dev/null| grep 'Writing' | awk '{print $4}'
}
function waiting {
 $curl $url 2>/dev/null| grep 'Waiting' | awk '{print $6}'
}
function accepts {
 $curl $url 2>/dev/null| awk NR==3 | awk '{print $1}'
}
function handled {
 $curl $url 2>/dev/null| awk NR==3 | awk '{print $2}'
}
function requests {
 $curl $url 2>/dev/null| awk NR==3 | awk '{print $3}'
}
$1

添加权限:

[root@centos ~]# chmod 755 /usr/local/sbin/ngx_status.sh

编辑zabbix_agent配置文件:

[root@centos ~]# vi /etc/zabbix/zabbix_agentd.conf

在Option:UserParameter处添加:UserParameter=nginx.status[*],/usr/local/sbin/ngx_status.sh $1

zabbix监控Nginx/Tomcat/MySQL的详细教程

重启服务:

[root@centos ~]# systemctl restart zabbix-agent

在A机器(服务端)测试:

[root@zabbix ~]# zabbix_get -s 192.168.234.125 -k 'nginx.status[accepts]'
6

在本机创建.xml文件并添加以下内容:(文件名称自定义)

<?xml version="1.0" encoding="UTF-8"?>

 4.0
 2019-02-11T07:29:29Z
 
  
   Templates
  
 
 
  
 
 
  
   {Template App NGINX:nginx.status[ping].last()}=0
   0
   
   nginx was down!
   0
   
   
   0
   4
   NGINX进程数:0,请注意
   0
   0
   
   
  
 
 
  
   nginx status connections
   900
   200
   0.0000
   100.0000
   1
   1
   0
   1
   0
   0.0000
   0.0000
   0
   0
   0
   0
   
    
     0
     0
     00C800
     0
     2
     0
     
      Template App NGINX
      nginx.status[active]
     
    
    
     1
     0
     C80000
     0
     2
     0
     
      Template App NGINX
      nginx.status[reading]
     
    
    
     2
     0
     0000C8
     0
     2
     0
     
      Template App NGINX
      nginx.status[waiting]
     
    
    
     3
     0
     C800C8
     0
     2
     0
     
      Template App NGINX
      nginx.status[writing]
     
    
   
  
  
   nginx status server
   900
   200
   0.0000
   100.0000
   1
   1
   0
   1
   0
   0.0000
   0.0000
   0
   0
   0
   0
   
    
     0
     0
     00C800
     0
     2
     0
     
      Template App NGINX
      nginx.status[accepts]
     
    
    
     1
     0
     C80000
     0
     2
     0
     
      Template App NGINX
      nginx.status[handled]
     
    
    
     2
     0
     0000C8
     0
     2
     0
     
      Template App NGINX
      nginx.status[requests]
     
    
   
  
 
 
  
   Service state
   
    
     0
     Down
    
    
     1
     Up
    
   
  
 

在zabbix前端页面点击配置→模板→导入:

zabbix监控Nginx/Tomcat/MySQL的详细教程

#导入刚才创建的xml文件即可

导入成功后在主机列表页面选择被监控的机器(B机器)链接该模板即可开始监控nginx

zabbix监控Tomcat

A机器:zabbix服务端(192.168.234.128) B机器:zabbix客户端(192.168.234.125)

在A机器安装zabbix-java-gateway:

[root@zabbix ~]# wget https://mirrors.tuna.tsinghua.edu.cn/zabbix/zabbix/4.0/rhel/7/x86_64/zabbix-java-gateway-4.0.14-1.el7.x86_64.rpm

[root@zabbix ~]# yum -y localinstall zabbix-java-gateway-4.0.14-1.el7.x86_64.rpm 

编辑gateway配置文件:

[root@zabbix ~]# vi /etc/zabbix/zabbix_java_gateway.conf 

去掉LISTEN_IP、LISTEN_PORT(监听端口)、START_POLLERS(进程数)的注释符号#:

zabbix监控Nginx/Tomcat/MySQL的详细教程

#LISTEN_IP定义被监控机器的地址,不指定默认监听全部机器

编辑server配置文件:

[root@zabbix ~]# vi /etc/zabbix/zabbix_server.conf

定义以下3个配置参数:

zabbix监控Nginx/Tomcat/MySQL的详细教程

启动zabbix-java-gateway服务:

[root@zabbix ~]# systemctl start zabbix-java-gateway

重启zabbix-server服务:

[root@zabbix ~]# systemctl restart zabbix-server

查看监听端口:

[root@zabbix ~]# netstat -lntp |grep java
tcp6  0  0 :::10052    :::*     LISTEN  8706/java 

开启JMX

在B机器编辑tomcat配置文件:

[root@centos ~]# vi /usr/local/tomcat/bin/catalina.sh 

添加以下内容:

export CATALINA_OPTS="$CATALINA_OPTS -Dcom.sun.management.jmxremote
-Djava.rmi.server.hostname=192.168.234.125
-Dcom.sun.management.jmxremote.port=9999
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=false"

#hostname定义B机器地址,端口9999(默认12345)

重启tomcat:

[root@centos ~]# /usr/local/tomcat/bin/shutdown.sh 

[root@centos ~]# /usr/local/tomcat/bin/startup.sh 

查看监听端口9999:

[root@centos ~]# netstat -lntp |grep 9999
tcp6  0  0 :::9999     :::*     LISTEN  25861/java 

进入zabbix前端页面添加主机:

zabbix监控Nginx/Tomcat/MySQL的详细教程

#与普通情况添加监控主机不同,监控B机器的tomcat需要配置JMX接口

模板链接JMX相关的两个模板:

zabbix监控Nginx/Tomcat/MySQL的详细教程

当JMX图标变绿即表示配置成功:

zabbix监控Nginx/Tomcat/MySQL的详细教程

zabbix监控MySQL

A机器:zabbix服务端(192.168.234.128) B机器:zabbix客户端(192.168.234.125)

zabbix_agent定义mysql监控的配置文件:/etc/zabbix/zabbix_agentd.d/userparameter_mysql.conf

在B机器登录mysql创建用户:

mysql> grant usage,process,replication client on *.* to zamysql@'localhost' identified by 'zamysql';

创建配置文件指定的目录:

[root@centos ~]# mkdir /var/lib/zabbix

创建my.cnf文件:

[root@centos ~]# vi /var/lib/zabbix/.my.cnf

#需要注意该文件是隐藏文件

添加以下内容:

[mysql]
host=localhost
user=zamysql
password='zamysql'
socket=/tmp/mysql.sock

[mysqladmin]
host=localhost
user=zamysql
password='zamysql'
socket=/tmp/mysql.sock

在A机器测试:

[root@zabbix ~]# zabbix_get -s 192.168.234.125 -p 10050 -k mysql.ping
1
[root@zabbix ~]# zabbix_get -s 192.168.234.125 -p 10050 -k mysql.version
mysql Ver 14.14 Distrib 5.6.43, for linux-glibc2.12 (x86_64) using EditLine wrapper
[root@zabbix ~]# zabbix_get -s 192.168.234.125 -p 10050 -k mysql.size
10240

#已成功获取数据

在zabbix前端页面添加主机:

zabbix监控Nginx/Tomcat/MySQL的详细教程

监控模板选择DB mysql:

zabbix监控Nginx/Tomcat/MySQL的详细教程

ZBX标准变为绿色表示成功:

zabbix监控Nginx/Tomcat/MySQL的详细教程

在监测→最新数据页面即可查看mysql监控数据:

zabbix监控Nginx/Tomcat/MySQL的详细教程

总结

以上所述是小编给大家介绍的zabbix监控Nginx/Tomcat/MySQL的详细教程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对创新互联网站的支持!如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!


文章名称:zabbix监控Nginx/Tomcat/MySQL的详细教程
文章源于:http://scyanting.com/article/jgddod.html