被监控的主机及mysql监控帐号,zabbix agent 2.0或以上(最好与zabbix-server版本相同),php, php-mysql(php版本没有限制,经测试5.3是能够的。最好版本不要过低),Percona Monitoring Plugins for Zabbixphp
https://www.cnblogs.com/fishparadise/p/9067471.htmlhtml
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';
修改成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/
/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
(若是是源码安装)
/usr/local/zabbix/bin/zabbix_get -s 192.168.1.51 -k system.cpu.util[,idle]
若是返回一个数字,证实是执行成功的。
用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更新数据间隔也能够修改。