zabbix 监控多实例mysql

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

原理说明:

通过自动发现规则来获取MySQL实例的端口,自动发现规则上的{$MYSQLPORT}是要传递给agent自动发现脚本的参数,这个值是从主机定义的宏{$MYSQLPORT}获取过来的,自动发现的脚本将其解析成{#MYSQLPORT}:

端口的形式,监控项原型再根据{#MYSQLPORT}的值来生成监控项,大致流程如下:

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

以下内容需要的脚本和xml文件下载地址 链接: https://pan.baidu.com/s/1ZP1ydYwfY65PU4Z08QM6fw 提取码: 7v4h

一、在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

MySQL数据监控案例_zabbix 监控多实例mysql相关推荐

  1. 徐无忌MySQL笔记:案例实战:如何实现MySQL数据库的读写分离?

    徐无忌MySQL笔记:案例实战:如何实现MySQL数据库的读写分离? 完成:第一遍 1.理想的主从架构实现的效果是怎样的? 主库负责所有读写操作,从库只实现对主库备份功能,这样的主从架构性价比是很低的 ...

  2. 怎么监控mysql数据变化_实时监控mysql数据库变化

    对于二次开发来说,很大一部分就找找文件和找数据库的变化情况 对于数据库变化.还没有发现比较好用的监控数据库变化监控软件. 今天,我就给大家介绍一个如何使用mysql自带的功能监控数据库变化 1.打开数 ...

  3. zabbix mysql监控告警_Zabbix监控mysql配置及故障告警配置

    同时介绍了触发器的创建及zabbix通过邮件方式告警配置. 一.配置自带模板监控mysql 1.提供配置文件模板 文件位置在源码包/usr/local/src/zabbix-3.0.4/conf/za ...

  4. mysql数据设置有效期_zabbix管理六之数据有效期设置

    数据有效期设置 先来看看设置数据有效期的方法: 找到自己要设置的监控项,如上图: 趋势存储数据和历史存储数据详解: 案例: 100台服务器,每台服务器有30个监控项,每个监控项60秒刷新一次,需要多大 ...

  5. 无法监控端口_zabbix 监控远程主机端口

    背景: 生产上突然发现 mysql 的某个VIP 地址,同网段的机器正常访问,另外一个网端内的机器无法连接,导致现网故障-.. 解决方法: 此次故障运维侧没有及时发现故障,导致故障时间长达10分钟,影 ...

  6. mysql数据表案例_mysql中库和表的简单操作案例

    mysql中库和表的简单操作案例 发布时间:2020-12-05 09:54:06 来源:亿速云 阅读:71 作者:小新 这篇文章主要介绍mysql中库和表的简单操作案例,文中介绍的非常详细,具有一定 ...

  7. java监控端口_zabbix监控Java 8080端口

    linux下端口和服务是对应的,Java进程启动时默认监听8080端口,如果服务挂掉则8080端口就没有了. lsof -i:8080 端口,如果没有任何的输出,说明该端口不在工作. 想在zabbix ...

  8. MySQL数据技术嘉年华,带你深入MySQL的世界

    点关注,不迷路 众所周知,MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),可以使用最常用的-结构化查询语言(SQL)进行管理.MySQL在DB-Engines数据库排行榜上稳居第二,再 ...

  9. mysql数据备份合理计划_计划备份mysql数据库

    1:mysql是我们使用最多的数据库,如果在日常中正确的对mysql数据进行备份,下面我们就来做这事,通过脚本来实现 ######################################### ...

  10. mysql数据备份方法_最快的MySql数据库备份方法

    最快的MySql数据库备份方法 使用MYSQL进行数据库备份,又很正规的数据库备份方法,同其他的数据库服务器有相同的概念,但有没有想过,MySQL会有更简捷的使用文件目录的备份方法,而且又快有好. 一 ...

最新文章

  1. 【3】npm run build Vue的项目,如何修改相对路径配置
  2. hibernate开启二级缓存
  3. python 字符串前面加u,r,b,f的含义
  4. Ubuntu16.04运行VoxelNetRos
  5. python命令式编程的概念,【Python】十分钟学会函数式编程
  6. c#中结构体和类的比较
  7. spring框架搭建第一天
  8. 使用C#进行系统编程
  9. Flutter AnimatedAlign 使用解析
  10. c++类中的static详解(续)
  11. haoi2018奇怪的背包题解
  12. Atitit 存储与数据库性能调优流程目录1. 数据库出现性能瓶颈,对外表现有几个方面:
  13. MATLAB去除多余点的命令,如何清除matlab命令窗口中已有的内容
  14. 无法访问共享计算机文件,电脑无法访问共享文件怎么解决?
  15. Win10系统修改用户名以及C盘下Users用户名实操手册(实测有效)
  16. 统计建模--学习笔记1
  17. oracle 转换为double,Oracle中的类型转换 (转)
  18. [激光原理与应用-23]:《激光原理与技术》-9- 激光产生技术-锁模技术
  19. 【译转】智能化css检测法,好优化拒绝冗杂代码
  20. 串口调试助手与CH340驱动分享

热门文章

  1. 索引、视图和同义词、序列
  2. 写项目文档比写代码难多了
  3. Unix编程之size_t、ssize_t
  4. mysql 四种隔离级别
  5. 网络管理常用命令(6/14) -netstat命令详解
  6. 实现二级菜单的滑动出现与消失(解决dispaly与transition冲突问题)
  7. Linux定时器的简单使用
  8. Ceph浅析”系列之四——Ceph的结构
  9. libevent源码深度剖析二
  10. H.264学习过程中遇到的英文缩写整理