阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Zabbix自定义监控MySQL性能状态

241次阅读
没有评论

共计 4604 个字符,预计需要花费 12 分钟才能阅读完成。

环境是 CentOS 6.5 x86_64 系统

Zabbix 版本:3.0.4

MySQL Server 版本:5.6.29 二进制安装

zabbix_agentd.conf 的配置文件如下:

[root@linuxidc alertscripts]# cat  /usr/local/zabbix/etc/zabbix_agentd.conf | grep -v ‘^#’ | grep -v ‘^$’
LogFile=/tmp/zabbix_agentd.log
EnableRemoteCommands=1
Server=10.18.3.193
ListenPort=10050
ServerActive=10.18.3.193
Hostname=10.18.3.191
AllowRoot=1
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/*.conf
UnsafeUserParameters=1
# 下面两行是自定义的 key
UserParameter=mysql.slave,/usr/local/zabbix/share/zabbix/alertscripts/check_mysql_slave.sh | grep -c ‘ok’
UserParameter=mysql.status[*],/usr/local/zabbix/share/zabbix/alertscripts/mysql_server_status.sh $1

查看 mysql 授权:

Zabbix 自定义监控 MySQL 性能状态

mysql 授权需要密码才能访问,但是使用密码 mysql 会提示明文密码,就会有下面的提示:

[root@linuxidc alertscripts]# sh check_mysql_slave.sh
Warning: Using a password on the command line interface can be insecure.
ok -slave is running

解决办法如下:

[root@linuxidc alertscripts]# cat /etc/my.cnf | tail -4
[client]
user = root
host = localhost
password = 1qaz@WSX

再次运行脚本:

[root@linuxidc alertscripts]# sh check_mysql_slave.sh
ok -slave is running

mysql 主从监控脚本,脚本中去掉用户,密码直接使用命令。

[root@linuxidc alertscripts]# cat check_mysql_slave.sh
#!/bin/bash
declare -a slave_is
slave_is=($(/data/mysql/bin/mysql -e “show slave status\G”|grep -E “Slave_IO_Running|Slave_SQL_Running:”|awk ‘{print $2}’))
if [“${slave_is[0]}” = “Yes” -a “${slave_is[1]}” = “Yes” ];then
    echo “ok -slave is running”
    exit 0
else
    echo “down -slave is not running”
    exit 2
fi

mysql_server_status 脚本,这块上面 my.cnf 填写以后,使用 mysqladmin 也就不提示了:

[root@linuxidc alertscripts]# cat mysql_server_status.sh
#!/bin/bash
source /etc/profile
mysqladmin=`which mysqladmin`
case $1 in
    Uptime)
        result=`${mysqladmin} status|cut -f2 -d”:”|cut -f1 -d”T”`
        echo $result
        ;;
    Com_update)
        result=`${mysqladmin} extended-status |grep -w “Com_update”|cut -d”|” -f3`
        echo $result
        ;;
    Slow_queries)
        result=`${mysqladmin} status |cut -f5 -d”:”|cut -f1 -d”O”`
        echo $result
        ;;
    Com_select)
        result=`${mysqladmin} extended-status |grep -w “Com_select”|cut -d”|” -f3`
        echo $result
                ;;
    Com_rollback)
        result=`${mysqladmin} extended-status |grep -w “Com_rollback”|cut -d”|” -f3`
                echo $result
                ;;
    Questions)
        result=`${mysqladmin} status|cut -f4 -d”:”|cut -f1 -d”S”`
                echo $result
                ;;
    Com_insert)
        result=`${mysqladmin} extended-status |grep -w “Com_insert”|cut -d”|” -f3`
                echo $result
                ;;
    Com_delete)
        result=`${mysqladmin} extended-status |grep -w “Com_delete”|cut -d”|” -f3`
                echo $result
                ;;
    Com_commit)
        result=`${mysqladmin} extended-status |grep -w “Com_commit”|cut -d”|” -f3`
                echo $result
                ;;
    Bytes_sent)
        result=`${mysqladmin} extended-status |grep -w “Bytes_sent” |cut -d”|” -f3`
                echo $result
                ;;
    Bytes_received)
        result=`${mysqladmin} extended-status |grep -w “Bytes_received” |cut -d”|” -f3`
                echo $result
                ;;
    Com_begin)
        result=`${mysqladmin} extended-status |grep -w “Com_begin”|cut -d”|” -f3`
                echo $result
                ;;
                       
        *)
        echo “Usage:$0(Uptime|Com_update|Slow_queries|Com_select|Com_rollback|Questions|Com_insert|Com_delete|Com_commit|Bytes_sent|Bytes_received|Com_begin)”
        ;;
esac

在 zabbix_server 获取 key 值,或是查看 zabbix_server.log 文件都可以排错。

[root@linuxidc bin]# ./zabbix_get -s 10.18.3.191 -k mysql.status[Uptime]
ZBX_NOTSUPPORTED: Unsupported item key.
[root@linuxidc bin]# ./zabbix_get -s 10.18.3.191 -k mysql.status[Uptime]
/usr/local/zabbix/share/zabbix/alertscripts/mysql_server_status.sh: line 4: mysqladmin: command not found
[root@linuxidc bin]# ./zabbix_get -s 10.18.3.191 -k mysql.status[Uptime]
414242

zabbix_agent.log 可以看到已经获取到自定义的 key:

Zabbix 自定义监控 MySQL 性能状态

添加自定义模板,模板名称随意给个和 mysql 相关的:

Zabbix 自定义监控 MySQL 性能状态

创建应用集:

Zabbix 自定义监控 MySQL 性能状态

添加监控项,一个 key 一个 key 添加,把脚本的 key 都添加进去。

Zabbix 自定义监控 MySQL 性能状态

如下所示:

Zabbix 自定义监控 MySQL 性能状态

mysql 状态这块只做了图形查看,并没有做触发器,只做了主从的触发器,需要的可以自己添加:

Zabbix 自定义监控 MySQL 性能状态

添加完成后可以添加一台 mysql 数据库查看下最新数据,是否成功了。

Zabbix 自定义监控 MySQL 性能状态

查看图形监控数据:

Zabbix 自定义监控 MySQL 性能状态

模板可以到 Linux 公社资源站下载:

—————————————— 分割线 ——————————————

免费下载地址在 http://linux.linuxidc.com/

用户名与密码都是www.linuxidc.com

具体下载目录在 /2017 年资料 / 3 月 /22 日 /Zabbix 自定义监控 MySQL 性能状态 /

下载方法见 http://www.linuxidc.com/Linux/2013-07/87684.htm

—————————————— 分割线 ——————————————

一些 Zabbix 相关教程集合

Ubuntu 14.04 下 Zabbix2.4.5 源码编译安装  http://www.linuxidc.com/Linux/2015-05/117657.htm

CentOS 7 LNMP 环境搭建 Zabbix3.0  http://www.linuxidc.com/Linux/2017-02/140134.htm

Ubuntu 16.04 安装部署监控系统 Zabbix2.4  http://www.linuxidc.com/Linux/2017-03/141436.htm

Zabbix 监控安装部署及警报配置  http://www.linuxidc.com/Linux/2017-03/141611.htm

Ubuntu 16.04 下安装部署 Zabbix3.0  http://www.linuxidc.com/Linux/2017-02/140395.htm

CentOS 6.3 下 Zabbix 监控 apache server-status http://www.linuxidc.com/Linux/2013-05/84740.htm

CentOS 7 下 Zabbix 3.0 安装详解 http://www.linuxidc.com/Linux/2017-03/141716.htm

64 位 CentOS 6.2 下安装 Zabbix 2.0.6   http://www.linuxidc.com/Linux/2014-11/109541.htm

ZABBIX 的详细介绍:请点这里
ZABBIX 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-03/142042.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计4604字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中