小知识:Zabbix实现监控多个mysql过程解析

一台服务器上开启了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配置文件

最后位置增加

?
1
2
3
4
5
6
7
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、增加配置文件

?
1
2
3
4
5
6
[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、增加执行脚本文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
[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过程解析-1猿站网-插图

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

%小知识:Zabbix实现监控多个mysql过程解析-2猿站网-插图

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

%小知识:Zabbix实现监控多个mysql过程解析-3猿站网-插图

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

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

%小知识:Zabbix实现监控多个mysql过程解析-4猿站网-插图

最终的效果是

%小知识:Zabbix实现监控多个mysql过程解析-5猿站网-插图

%小知识:Zabbix实现监控多个mysql过程解析-6猿站网-插图

Zabbix131

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

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:zabbix 监控mysql的方法

2023-3-21 13:49:17

建站知识

小知识:zabbix监控4.4升级至5.0的详细教程

2023-3-21 14:00:20

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索