一台服务器上开启了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}
b.监控项原型 根据获取的端口来生成对应的监控项,需要使用到自动发现宏{#MYSQLPORT}
3、在需要监控的主机上增加新创建的模板
4、在需要监控的主机上定义一个宏{$MYSQLPORT},对应要监控的端口,如3306_3307_3308
三、等待收集数据完成,如果没有数据的话,手动测试下具体
例如在zabbixserver上执行操作,例如测试mysql 3306是否存活,1表示up,0表示down。
最终的效果是
Zabbix131
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]