国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Zabbix實(shí)現(xiàn)監(jiān)控多個(gè)mysql過程解析

瀏覽:130日期:2023-04-06 15:09:05

一臺(tái)服務(wù)器上開啟了3個(gè)mysql實(shí)例進(jìn)程,占用不同的端口 3306、3307、3308

原理說明:

通過自動(dòng)發(fā)現(xiàn)規(guī)則來獲取MySQL實(shí)例的端口,自動(dòng)發(fā)現(xiàn)規(guī)則上的{$MYSQLPORT}是要傳遞給agent自動(dòng)發(fā)現(xiàn)腳本的參數(shù),這個(gè)值是從主機(jī)定義的宏{$MYSQLPORT}獲取過來的,自動(dòng)發(fā)現(xiàn)的腳本將其解析成{#MYSQLPORT}:端口的形式,監(jiān)控項(xiàng)原型再根據(jù){#MYSQLPORT}的值來生成監(jiān)控項(xiàng),大致流程如下:

主機(jī)定義宏{$MYSQLPORT}->自動(dòng)發(fā)現(xiàn)規(guī)則鍵值{$MYSQLPORT}->調(diào)用agent上自動(dòng)發(fā)現(xiàn)腳本并解析成{#MYSQLPORT} : 端口 ->監(jiān)控項(xiàng)原型{#MYSQLPORT}->自動(dòng)生成主機(jī)監(jiān)控項(xiàng)

一、在mysql多實(shí)例服務(wù)器上的操作

1、授權(quán)zabbix監(jiān)控mysql賬號(hào),在每個(gè)實(shí)例下都需要。

此處 賬號(hào)為 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  ###自動(dòng)發(fā)現(xiàn)不同端口     UserParameter=mysql.status[*],/etc/zabbix/bin/mysql_status.sh $1 $2   ###性能監(jiān)控信息     UserParameter=mysql.ping[*],/etc/zabbix/bin/mysql_alive.sh $1      ### 是否存活     UserParameter=mysql.ms.check[*],/etc/zabbix/bin/mysql_slave_status.sh $1 ### 從庫狀態(tài)是否正常     UserParameter=mysql.ms.time[*],/etc/zabbix/bin/mysql_slave_time.sh $1  ### 從庫是否有延遲

4、增加執(zhí)行腳本文件

[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、導(dǎo)入template_multi_MySQL.xml 模板信息,也可以參考xml文件手動(dòng)增加。

2、在模版上創(chuàng)建自動(dòng)發(fā)現(xiàn)的規(guī)則,在自動(dòng)發(fā)現(xiàn)規(guī)則中需要定義兩個(gè)東西:
a.鍵值 用來自動(dòng)獲取MySQL實(shí)例的端口,需要使用到主機(jī)宏{$MYSQLPORT}

b.監(jiān)控項(xiàng)原型 根據(jù)獲取的端口來生成對(duì)應(yīng)的監(jiān)控項(xiàng),需要使用到自動(dòng)發(fā)現(xiàn)宏{#MYSQLPORT}

3、在需要監(jiān)控的主機(jī)上增加新創(chuàng)建的模板

4、在需要監(jiān)控的主機(jī)上定義一個(gè)宏{$MYSQLPORT},對(duì)應(yīng)要監(jiān)控的端口,如3306_3307_3308

三、等待收集數(shù)據(jù)完成,如果沒有數(shù)據(jù)的話,手動(dòng)測試下具體

例如在zabbixserver上執(zhí)行操作,例如測試mysql 3306是否存活,1表示up,0表示down。

最終的效果是

Zabbix131

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持。

標(biāo)簽: Zabbix
相關(guān)文章:
主站蜘蛛池模板: 类乌齐县| 清新县| 通辽市| 高州市| 东城区| 基隆市| 弥勒县| 松潘县| 嘉兴市| 山丹县| 揭东县| 河东区| 从化市| 城口县| 长宁区| 浦县| 景宁| 大英县| 泽州县| 鄂州市| 云南省| 开平市| 徐闻县| 上饶市| 淄博市| 双辽市| 嘉峪关市| 华池县| 谷城县| 新竹市| 北海市| 朔州市| 大邑县| 祁连县| 余姚市| 闽侯县| 诏安县| 邓州市| 咸丰县| 桦南县| 舒兰市|