您的位置:首页 > 数据库 > SQL

利用zabbix监控mysql服务器

2017-06-18 10:17 483 查看
使用mysql自带的模板,可以监控如下内容:OPS(增删改查)、mysql请求流量带宽,mysql响应流量带宽。

编写check_mysql.sh脚本用于获取mysql性能指标数据

[root@pms-mysql zabbix]# vi check_mysql.sh

#!/bin/bash

# 用户名

MYSQL_USER='test'

# 密码

MYSQL_PWD='123'

# 主机地址/IP

MYSQL_HOST='127.0.0.1'

# 端口

MYSQL_PORT='3306'

# 数据连接

MYSQL_CONN="/usr/bin/mysqladmin -u${MYSQL_USER} -p${MYSQL_PWD} -h${MYSQL_HOST} -P${MYSQL_PORT}"

# 参数是否正确

if [ $# -ne "1" ];then

    echo "arg error!"

fi

# 获取数据

case $1 in

    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

                ;;

        *)

        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

[root@pms-mysql zabbix]# chmod +x check_mysql.sh   //添加脚本执行权限

[root@pms-mysql zabbix]# vi etc/zabbix_agentd.conf   //修改agentd配置文件

添加:

UserParameter=mysql.version,mysql -V  //获取mysql版本信息

UserParameter=mysql.status[*],/usr/local/zabbix/check_mysql.sh $1  //获取mysql性能指标

UserParameter=mysql.ping,netstat -ntlp |grep 3306| wc|awk ‘{print $1}’ //获取mysql运行状态

[root@pms-mysql zabbix]# chmod +s /bin/netstat check_mysql.sh  //添加执行netstat权限

在服务端添加mysql监控的模板

[root@zabbix ~]# /usr/local/zabbix/bin/zabbix_get -s 192.168.1.247 -p10050 -k mysql.ping //服务器端测试

1
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: