利用Percona monitoring for zabbix監控MySQL

系統要求

被監控的主機及mysql監控帳號,zabbix agent 2.0或以上(最好與zabbix-server版本相同),php, php-mysql(php版本沒有限制,經測試5.3是能夠的。最好版本不要過低),Percona Monitoring Plugins for Zabbixphp

安裝zabbix agent

https://www.cnblogs.com/fishparadise/p/9067471.htmlhtml

安裝percona plugin

percona plugin須要php的支持,先安裝依賴包:前端

yum install php php-mysql
wget https://www.percona.com/downloads/percona-monitoring-plugins/percona-monitoring-plugins-1.1.7/binary/redhat/7/x86_64/percona-zabbix-templates-1.1.7-2.noarch.rpm

或到percona官網下載rpm包mysql

https://www.percona.com/downloads/percona-monitoring-plugins/LATEST/
rpm -ivh percona-zabbix-templates-1.1.7-2.noarch.rpm

爲被監控的mysql增長一個專用帳號web

mysql>CREATE USER 'zabbix_monitor'@'127.0.0.1' IDENTIFIED BY 'zabbix456';
mysql>GRANT SELECT, PROCESS, SUPER, REPLICATION CLIENT ON *.* TO 'zabbix_monitor'@'127.0.0.1';

配置percona plugin

修改成mysql帳號zabbix_monitorsql

vim /var/lib/zabbix/percona/scripts/ss_get_mysql_stats.php
$mysql_user = 'zabbix_monitor';
$mysql_pass = 'zabbix456';
$mysql_port = 3306;
vim /var/lib/zabbix/percona/scripts/get_mysql_stats_wrapper.sh
HOST=127.0.0.1

若是要修改percona plugin收集數據的時間間隔,修改下面代碼中的300爲適合的數字,單位是」秒」。vim

elif [ -e $CACHEFILE ]; then
    # Check and run the script
    TIMEFLM=`stat -c %Y /tmp/$HOST-mysql_cacti_stats.txt`
    TIMENOW=`date +%s`
    if [ `expr $TIMENOW - $TIMEFLM` -gt 300 ]; then
        rm -f $CACHEFILE
        $CMD 2>&1 > /dev/null
    fi
else

把percona要執行的執行文件放到zabbix的include目錄下(zabbix調用此文件)。zabbix agent用rpm安裝默認的是:/etc/zabbix/zabbix_agentd.d/目錄,具體看zabbix agent的配置文件。app

cp /var/lib/zabbix/percona/templates/userparameter_percona_mysql.conf /etc/zabbix/zabbix_agentd.d/

在client端測試

/var/lib/zabbix/percona/scripts/get_mysql_stats_wrapper.sh gg

若是返回一個數字,證實是執行成功的。測試

注意:經過vim get_mysql_stats_wrapper.sh中的CACHEFILE="/tmp/$HOST-mysql_cacti_stats.txt"默認會在/tmp/下生成一個臨時文件,這個文件在測試完要手動刪除!不然會形成程序沒法刪除這個文件,而致使zabbix沒法收集數據!code

若是用root用戶登陸手工測試生成的文件是沒有數據,使用如下命令再測試下:

/usr/bin/php -q /var/lib/zabbix/percona/scripts/ss_get_mysql_stats.php --host 127.0.0.1 --items gg

可能會返回如下的錯誤:

PHP MySQLi extension is not loaded

安裝php-mysql便可

yum install php-mysql

在server端測試

(若是是源碼安裝)

/usr/local/zabbix/bin/zabbix_get -s 192.168.1.51 -k system.cpu.util[,idle]

若是返回一個數字,證實是執行成功的。

配置zabbix-server前端頁面

用rpm安裝percona plugin,會在/var/lib/zabbix/percona/templates生成一個模板,但percona-zabbix-templates-1.1.7-2.noarch.rpm生成的模板zabbix_agent_template_percona_mysql_server_ht_2.0.9-sver1.1.7.xml是for zabbix 2.0的版本,已經很舊,不適用了。

在網上找到一個for zabbix 3.0的模板,登陸
zabbix web:Configuration -> Templates -> 右上角的Import,把Screens, Maps, Images都選中,導入

導入的模板的Itmes更新數據間隔也能夠修改。

相關文章
相關標籤/搜索