zabbix 监控多个mysql_zabbix 监控多实例mysql[通俗易懂]

zabbix 监控多个mysql_zabbix 监控多实例mysql[通俗易懂]zabbix监控多实例mysql一台服务器上开启了3个mysql实例进程,占用不同的端口3306、3307、3308原理说明:通过自动发现规则来获取MySQL实例的端口,自动发现规则上的{$MYSQLPORT}是要传递给agent自动发现脚本的参数,这个值是从主机定义的宏{$MYSQLPORT}获取过来的,自动发现的脚本将其解析成{#MYSQLPORT}:端口的形式,监控项原型再根据{#MYS…

大家好,又见面了,我是你们的朋友全栈君。

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}

fd5bea689be2729781ca5d7b001e7295.png

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

d7eb6547cac68205a3197c04e549a055.png

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

27179c8ccf2f48492e8bd81bbe481ee5.png

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

2ebf680de9d32684f5d5e0ab4fce9f60.png

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

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

48dcc35c925bd0a67b7a4b5c3b9239bb.png

最终的效果是

2f1bf5a455831b8f29027c89e1a8a57c.png

5dc7174131bceed7457f6b92d735432f.png

Zabbix131

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/133393.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • webservice技术介绍

    一、WebService到底是什么?   一言以蔽之:WebService是一种跨编程语言和跨操作系统平台的远程调用技术。   所谓跨编程语言和跨操作平台,就是说服务端程序采用java编写,客户端程序则可以采用其他编程语言编写,反之亦然!跨操作系统平台则是指服务端程序和客户端程序可以在不同的操作系统上运行。    所谓远程调用,就是一台计算机a上的一个程序可以调用到另外一台

  • c#中Invoke方法

    c#中Invoke方法invoke方法的初衷是为了解决在某个非某个控件创建的线程中刷新该控件可能会引发异常的问题。说的可能比较拗口,举个例子:主线程中存在一个文本控件,在一个子线程中要改变该文本的值,此时会有可能引发异常。为了避免该问题,需要在子线程中使用invoke方法来封装刷新文本内容的函数。Invoke或者BeginInvoke去调用,两者的区别就是Invoke会导致工作线程等待,而BeginIn

  • android 换机 软件 评比,安卓一键换机软件哪个好?手机换机软件排行榜TOP3推荐…

    android 换机 软件 评比,安卓一键换机软件哪个好?手机换机软件排行榜TOP3推荐…原标题:安卓一键换机软件哪个好?手机换机软件排行榜TOP3推荐买了新的安卓手机后,旧手机里很多数据不知道怎么导入新手机,同品牌换机可以用自带的换机软件。但跨品牌手机,就会存在软件不兼容等诸多不便。比如小米手机换华为,vivo手机换OPPO,这个问题困扰着很多换机一族。今天就给大家推荐小编私藏的手机换机软件TOP3:1⃣️手机克隆★★★★☆这款是华为自带的换机软件,同品牌的手机资料如视频照片、音乐文…

  • 对象数组「建议收藏」

    对象数组「建议收藏」定义一组多个对象的变量,就要用对象数组。对象数组的定义包含动态初始(类对象数组名[]=new类[长度];),数组里的每个元素都是引用类型的默认值;静态初始化(类对象数组名称[

  • docker部署web项目_小钢炮docker安装web

    docker部署web项目_小钢炮docker安装web前言前面我们运行的容器并没有一些什么特别的用处。接下来让我们尝试使用docker构建一个web应用程序。我们将在docker容器中运行一个PythonFlask应用来运行一个web

  • 关于我妈的一切_bool flag=false

    关于我妈的一切_bool flag=falseFLAG_ACTIVITY_MULTIPLE_TASK总结:1、使用改标记,需要自行管理Activity2、需要与FLAG_ACTIVITY_NEW_DOCUMENT或者FLAG_ACTIVITY_NEW_TASK共同使用/***Thisflagisusedtocreateanewtaskandlaunchanactivityinto…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号