Zabbix监控Mysql多实例自动添加

1、定义每个实例的端口

cat mysql_port
3306
3307
3308
3309
3310
 3311
3312
3313

2、给所有实例创建一个zabbix用户只允许本地访问,生产环境具体权限各位看官自己看着给吧O(∩_∩)O

GRANT ALL PRIVILEGES ON *.* TO [email protected]‘127.0.0.1‘ IDENTIFIED BY ‘zabbix‘;

3、创建自动发现MySQL端口脚本

cat /data/PRG/zabbix/scripts/discovery_mysql.sh

#!/bin/bash
# -------------------------------------------------------------------------------
# Script_name: discovery_mysql.sh
# Revision:    1.0
# Date:        2017/03/09
# Author:      kbsonlong
# Email:       [email protected]
# Website:     www.along.party
# -------------------------------------------------------------------------------

res=`cat /data/PRG/zabbix/scripts/mysql_port|grep -v "^#"`
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‘

4、创建MySQL检测脚本

# cat /data/PRG/zabbix/scripts/check_Multimysql.sh
#!/bin/bash
# -------------------------------------------------------------------------------
# FileName:    check_Multimysql.sh
# Revision:    1.0
# Date:        2017/03/09
# Author:      kbsonlong
# Email:       [email protected]
# Website:     www.along.party
# License:     GPL
# -------------------------------------------------------------------------------

# 用户名
MYSQL_USER=‘zabbix‘

# 密码
MYSQL_PWD=‘zabbix‘

# 主机地址/IP
MYSQL_HOST=‘127.0.0.1‘

# 端口
MYSQL_PORT=$2

# 数据连接
MYSQL_CONN="/usr/bin/mysqladmin -u${MYSQL_USER} -p${MYSQL_PWD} -h${MYSQL_HOST} -P${MYSQL_PORT}"

##help函数
help() {
        echo "Usage:$0  [ping|Uptime|Com_update|Slow_queries|Com_select|Com_rollback|Questions|Com_insert|Com_delete|Com_commit|Bytes_sent|Bytes_received|Com_begin]  port"
}

# 参数是否正确
if [ $# -lt "2" ];then
    echo "参数缺失!"
    help
    exit 2
fi 

# 获取数据
case $1 in
    ping)
        result=`${MYSQL_CONN} ping | grep -c alive`
        echo $result
        ;;
    Uptime)
        result=`${MYSQL_CONN} status|cut -f2 -d":"|cut -f1 -d"T"`
        echo $result
        ;;
    Com_update)
        result=`${MYSQL_CONN} extended-status |grep -w "Com_update"|cut -d"|" -f3`
        echo $result
        ;;
    Slow_queries)
        result=`${MYSQL_CONN} status |cut -f5 -d":"|cut -f1 -d"O"`
        echo $result
        ;;
    Com_select)
        result=`${MYSQL_CONN} extended-status |grep -w "Com_select"|cut -d"|" -f3`
        echo $result
                ;;
    Com_rollback)
        result=`${MYSQL_CONN} extended-status |grep -w "Com_rollback"|cut -d"|" -f3`
                echo $result
                ;;
    Questions)
        result=`${MYSQL_CONN} status|cut -f4 -d":"|cut -f1 -d"S"`
                echo $result
                ;;
    Com_insert)
        result=`${MYSQL_CONN} extended-status |grep -w "Com_insert"|cut -d"|" -f3`
                echo $result
                ;;
    Com_delete)
        result=`${MYSQL_CONN} extended-status |grep -w "Com_delete"|cut -d"|" -f3`
                echo $result
                ;;
    Com_commit)
        result=`${MYSQL_CONN} extended-status |grep -w "Com_commit"|cut -d"|" -f3`
                echo $result
                ;;
    Bytes_sent)
        result=`${MYSQL_CONN} extended-status |grep -w "Bytes_sent" |cut -d"|" -f3`
                echo $result
                ;;
    Bytes_received)
        result=`${MYSQL_CONN} extended-status |grep -w "Bytes_received" |cut -d"|" -f3`
                echo $result
                ;;
    Com_begin)
        result=`${MYSQL_CONN} extended-status |grep -w "Com_begin"|cut -d"|" -f3`
                echo $result
                ;; 

        *)
        help
        ;;
esac

5、测试脚本是否正常

# bash discovery_mysql.sh
{
        "data":[
         {
                        "{#MYSQLPORT}":"3306"},
         {
                        "{#MYSQLPORT}":"3307"},
         {
                        "{#MYSQLPORT}":"3308"},
         {
                        "{#MYSQLPORT}":"3309"},
         {
                        "{#MYSQLPORT}":"3310"},
         {
                        "{#MYSQLPORT}":"3311"},
         {
                        "{#MYSQLPORT}":"3312"},
         {
                        "{#MYSQLPORT}":"3313"}
         ]
}

# bash check_Multimysql.sh
参数缺失!
Usage:check_Multimysql.sh  [ping|Uptime|Com_update|Slow_queries|Com_select|Com_rollback|Questions|Com_insert|Com_delete|Com_commit|Bytes_sent|Bytes_received|Com_begin]  port
# bash check_Multimysql.sh ping 3306
1
# bash check_Multimysql.sh Uptime 3306
18180446

6、zabbix agent配置文件添加自定义脚本,并重启zabbix agent

vim /data/PRG/zabbix/etc/zabbix_agentd.conf

UserParameter=mysql_discovery[*],/bin/bash /data/PRG/zabbix/scripts/discovery_mysql.sh
#####$1==command   $2===port
UserParameter=mysql.status[*],/data/PRG/zabbix/scripts/check_mysql.sh $1 $2
UserParameter=mysql.ping[*],/data/PRG/zabbix/scripts/check_mysql.sh ping $1

/etc/init.d/zabbix_agentd restart

7、使用zabbix_get检查定义的key是否生效

# /usr/local/zabbix/bin/zabbix_get -s 192.168.62.200 -k mysql.ping[3307]
1
# /usr/local/zabbix/bin/zabbix_get -s 192.168.62.200 -k mysql.status[Uptime,3307]
18180813
# /usr/local/zabbix/bin/zabbix_get -s 192.168.62.200 -k mysql.status[Uptime,3306]
18180842
# /usr/local/zabbix/bin/zabbix_get -s 192.168.62.200 -k mysql.status[Uptime,3310]
18180847
# /usr/local/zabbix/bin/zabbix_get -s 192.168.62.200 -k mysql.status[Bytes_sent,3310]
58803854473

8、导入模板Template Multi Mysql.xml

9、被监控主机关联模板

自动发现规则mysql_discovery

自动添加的监控项

最新监控数据

 

时间: 2024-07-29 00:36:45

Zabbix监控Mysql多实例自动添加的相关文章

zabbix监控mysql多实例和mariadb自定义脚本及其部署

最近新部署zabbix监控,发现有很多DB服务器都是mysql多实例的状态,mpm默认的mysql监控无法有效的监控mysql的运行状态和复制关系,故针对双实例的mysql制作的手工的zabbix脚本监控如下 首先新建新的zabbix的mysql多实例监控模板,操作如下 名称 为模板信息名称 类型 因为使用的脚本出发所以修改成zabbix捉捕器 键值 脚本返回的信息,可以为数值,也可以是字元,这里定义为字元 数据类型 字元 同时也可以设置主动捕捉,如下:监控多实例端口状态 名称 为模板信息名称

zabbix监控MySQL多实例实践

一.实践背景:一台机器上部署了多个MySQL实例,每个实例使用不同的端口,需要通过zabbix将其都纳入监控中. 二.实践方法及原理说明:1.在Zabbix上创建监控MySQL数据库使用的模版,导入案例模版:链接: https://pan.baidu.com/s/1nXooNPMXrmaAQidRrxVOLg 提取码: ure1 2.在模版上创建自动发现的规则,在自动发现规则中需要定义两个东西:a.键值 用来自动获取MySQL实例的端口,需要使用到主机宏{$MYSQLPORT} b.监控项原型

zabbix监控mysql多实例自发现监控

系统运维工程师   李超 1.定义每个实例的端口 cat mysql_port  33063307330833093310  331133123313 2.给所有实例创建一个zabbix用户只允许本地访问,生产环境具体权限各位看官自己看着给吧O(∩_∩)O GRANT ALL PRIVILEGES ON *.* TO [email protected]'127.0.0.1' IDENTIFIED BY 'zabbix'; 3.创建自动发现MySQL端口脚本 cat /data/PRG/zabbi

Zabbix监控Mysql、Apache、Nginx应用实战案例

Zabbix对第三方应用软件的监控,主要有两个工作难点:一个是编写自定义监控脚本:另一个是在编写模板并导入zabbix web中,编写脚本这个要根据监控需求定制即可,而编写模板文件则相对来说有点难度,不过网上已经有很多已经写好的模板,可以直接拿来使用.所以,Zabbix对应用软件的监控其实并不难. 一.zabbix监控mysql应用实战 本次博文首先介绍的是Zabbix对Mysql的监控,这个是最简单的,因为Zabbix已经自带了Mysql监控的模板,我们只需编写一个监控Mysql的脚本即可!以

zabbix监控mysql性能

今天来看看zabbix如何监控mysql性能,这边使用mysql自带的模板,可以监控如下内容:OPS(增删改查).mysql请求流量带宽,mysql响应流量带宽,最后会附上相应的监控图! 编写check_mysql.sh脚本 用于获取mysql性能指标数据,你需要修改相应的数据库信息 # vim /usr/local/zabbix-2.4.4/scripts/chk_mysql.sh #脚本如下: #!/bin/bash # -----------------------------------

zabbix 监控MySQL

文章:http://blog.sctux.com/?p=396 现在我来说一下我的监控环境 zabbix-3.0.3 MySQL-5.6.23 1.首先我们要登录MySQL,创建一个监控MySQL的用户 grant replication client on *.* to [email protected]'localhost'  IDENTIFIED BY 'lybackup'; 2.根据zabbix监控MySQL的key改写脚本 *******************************

使用zabbix监控mysql主从状态

公司mysql架构为一主多从.在日常使用过程中我们经常会遇到主从不同步的情况,为了及时处理此问题现使用zabbix监控mysql主从状态并设置触发器,如有异常则发送邮件报警. 我们都知道使用命令"show slave status \G"可以查看mysql从的状态,下面用脚本方式检查其状态. 在mysql-slave中进入zabbix-agent目录创建脚本文件. cat mysql_slave_status.sh #!/bin/bash /usr/local/mysql/bin/my

Zabbix 监控Mysql数据库及主从数据库

Zabbix监控mysql主从数据库在脚步出现用户名和密码是会出现如下报错"Warning: Using a password on the command line interface can be insecure",报错原因是mysql 5.6版本增加了密码安全策略,之前版本可以使用的命令行里加上密码就会强制报错,所以使用zabbix监控mysql的时候,就会由于收到zabbix客户端日志报错信息.结合了网友的解决方案,现将整理出来供大家参考. 一,zabbix被监控端的设置:

Zabbix 监控 Mysql 状态

简介: 如何使用 Zabbix 来监控 Mysql 状态 ? Zabbix 有自带监控 Mysql 的模板,但是却不能直接使用.. 需要我们根据模板提供的 Key 自己写脚本获取数据 1.查看都有哪些 Key > Configuration -> Templates ## 在此模板页中,可以看到 Template App MySQL 模板中有 14 个 Items ,我们需要自己写脚本获取这 14 个值 ## 分别是:Com_select.Com_insert .Com_update .Com