欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Zabbix实现监控多个mysql过程解析

程序员文章站 2022-03-21 11:35:56
一台服务器上开启了3个mysql实例进程,占用不同的端口 3306、3307、3308原理说明:通过自动发现规则来获取mysql实例的端口,自动发现规则上的{$mysqlport}是要传递给agent...

一台服务器上开启了3个mysql实例进程,占用不同的端口 3306、3307、3308

原理说明:

通过自动发现规则来获取mysql实例的端口,自动发现规则上的{$mysqlport}是要传递给agent自动发现脚本的参数,这个值是从主机定义的宏{$mysqlport}获取过来的,自动发现的脚本将其解析成{#mysqlport}:端口的形式,监控项原型再根据{#mysqlport}的值来生成监控项,大致流程如下:

主机定义宏{$mysqlport}->自动发现规则键值{$mysqlport}->调用agent上自动发现脚本并解析成{#mysqlport} : 端口 ->监控项原型{#mysqlport}->自动生成主机监控项

一、在mysql多实例服务器上的操作

1、授权zabbix监控mysql账号,在每个实例下都需要。

此处 账号为 zabbixagent,密码为: zabbix131

grant usage,process,replication client,replication slave on *.* to 'zabbixagent'@'localhost' identified by 'zabbix131';
flush privileges;

2、修改zabbix_agentd.conf配置文件

最后位置增加

     unsafeuserparameters=1
     enableremotecommands=1
     include=/etc/zabbix/etc/zabbix_agentd.conf.d/*.conf
[root@mysql zabbix]# vi /etc/zabbix/etc/zabbix_agentd.conf
     unsafeuserparameters=1
     enableremotecommands=1
     include=/etc/zabbix/etc/zabbix_agentd.conf.d/*.conf

3、增加配置文件

[root@mysql etc]# vim /etc/zabbix/etc/zabbix_agentd.conf.d/check_mysql.conf
     userparameter=mysql_discovery[*],/etc/zabbix/bin/discovery_mysql.sh $1  ###自动发现不同端口
     userparameter=mysql.status[*],/etc/zabbix/bin/mysql_status.sh $1 $2   ###性能监控信息
     userparameter=mysql.ping[*],/etc/zabbix/bin/mysql_alive.sh $1      ### 是否存活
     userparameter=mysql.ms.check[*],/etc/zabbix/bin/mysql_slave_status.sh $1 ### 从库状态是否正常
     userparameter=mysql.ms.time[*],/etc/zabbix/bin/mysql_slave_time.sh $1  ### 从库是否有延迟

4、增加执行脚本文件

[root@mysql etc]# ll /etc/zabbix/bin/
total 716
     -rwxr-xr-x 1 root root  441 jul 22 11:36 discovery_mysql.sh
     -rwxr-xr-x 1 root root  401 jul 22 11:36 mysql_alive.sh
     -rwxr-xr-x 1 root root  303 jul 22 15:10 mysql_slave_status.sh
     -rwxr-xr-x 1 root root  286 jul 22 15:10 mysql_slave_time.sh
     -rwxr-xr-x 1 root root  299 jul 22 11:36 mysql_status.sh
     -rwxr-xr-x 1 root root  370 jul 22 11:36 mysql_version.sh
[root@mysql etc]# more /etc/zabbix/bin/discovery_mysql.sh
     res=`echo $1| sed "s/_/\n/g"`;
     port=($res)
     printf '{\n'
     printf '\t"data":[\n'
     for key in ${!port[@]}
     do
       if [[ "${#port[@]}" -gt 1 && "${key}" -ne "$((${#port[@]}-1))" ]];
     then
         printf '\t {\n'
         printf "\t\t\t\"{#mysqlport}\":\"${port[${key}]}\"},\n"
     else [[ "${key}" -eq "((${#port[@]}-1))" ]]
         printf '\t {\n'
         printf "\t\t\t\"{#mysqlport}\":\"${port[${key}]}\"}\n"
     fi
     done
     printf '\t ]\n'
     printf '}\n'
[root@mysql etc]# more /etc/zabbix/bin/mysql_status.sh
     #!/bin/bash
     var=$1
     mysql=/usr/local/mysql/bin/mysql
     mysql_user="zabbixagent"
     mysql_password=zabbix131
     mysql_sock_dir="/tmp/mysql$2.sock"
     ${mysql} -u${mysql_user} -p${mysql_password} -s ${mysql_sock_dir} -e "show global status;" 2> /dev/null |grep -v variable_name|grep "\b${var}\b"|awk '{print $2}'
[root@mysql etc]# more /etc/zabbix/bin/mysql_alive.sh
     #!/bin/bash
     mysqladmin=/usr/local/mysql/bin/mysqladmin
     mysql_userdd="zabbixagent"
     mysql_password=zabbix131
     mysql_sock_dir="/tmp/mysql$1.sock"
     ${mysqladmin} -u${mysql_user} -p${mysql_password} -s ${mysql_sock_dir} ping|grep -c alive
[root@mysql etc]# more /etc/zabbix/bin/mysql_slave_status.sh
     #!/bin/bash
     #var=$1
     mysql=/usr/local/mysql/bin/mysql
     mysql_userdd="zabbixagent"
     mysql_password=zabbix131
     mysql_sock_dir="/tmp/mysql$1.sock"
     ${mysql} -u${mysql_user} -p${mysql_password} -s ${mysql_sock_dir} -e "show slave status\g;" 2> /dev/null|grep -e 'slave_io_running: yes|slave_sql_running: yes'|grep -c yes
[root@mysql etc]# more /etc/zabbix/bin/mysql_slave_time.sh
     #!/bin/bash
     #var=$1
     mysql=/usr/local/mysql/bin/mysql
     mysql_userdd="zabbixagent"
     mysql_password=zabbix131
     mysql_sock_dir="/tmp/mysql$1.sock"
     ${mysql} -u${mysql_user} -p${mysql_password} -s ${mysql_sock_dir} -e "show slave status\g;" 2> /dev/null|grep -e 'seconds_behind_master'|awk '{print $2}'

5、重启 zabbix_agentd

[root@mysql zabbix_agentd.d]# systemctl restart zabbix-agent

二、zabbix页面上操作

1、导入template_multi_mysql.xml 模板信息,也可以参考xml文件手动增加。

2、在模版上创建自动发现的规则,在自动发现规则中需要定义两个东西:
a.键值 用来自动获取mysql实例的端口,需要使用到主机宏{$mysqlport}

Zabbix实现监控多个mysql过程解析

b.监控项原型 根据获取的端口来生成对应的监控项,需要使用到自动发现宏{#mysqlport}

Zabbix实现监控多个mysql过程解析

3、在需要监控的主机上增加新创建的模板

Zabbix实现监控多个mysql过程解析

4、在需要监控的主机上定义一个宏{$mysqlport},对应要监控的端口,如3306_3307_3308

Zabbix实现监控多个mysql过程解析

三、等待收集数据完成,如果没有数据的话,手动测试下具体

例如在zabbixserver上执行操作,例如测试mysql 3306是否存活,1表示up,0表示down。

Zabbix实现监控多个mysql过程解析

最终的效果是

Zabbix实现监控多个mysql过程解析

Zabbix实现监控多个mysql过程解析

zabbix131

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。