1. 程式人生 > 實用技巧 >zabbix 監控多例項mysql

zabbix 監控多例項mysql

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