1、在已有的lamp或者lnmp的基础上安装zabbix,安装一些依赖包:
yum -y install mysql-devel libcurl-devel net-snmp-devel
2、添加用户:
groupadd zabbixuseradd zabbix -g zabbix
3、创建数据库,添加授权账号
create database zabbix character set utf8;grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';
4、编译安装zabbix
下载地址:
wget http://jaist.dl.sourceforge.net/project/zabbix/zabbix%20latest%20stable/2.2.0/zabbix-2.2.0.tar.gztar zxf zabbix-2.2.0.tar.gzcd zabbix-2.2.0./configure --prefix=/usr/local/zabbix --enable-server --enable-agent \--with-mysql --with-net-snmp --with-libcurlmake install
5、导入数据库
mysql -uzabbix -pzabbix -hlocalhost zabbix < database/mysql/schema.sqlmysql -uzabbix -pzabbix -hlocalhost zabbix /etc/services /etc/rc.localecho /etc/init.d/zabbix_agentd start >> /etc/rc.local
9、web页面配置,配置http访问好了后web登陆:http://ip/zabbix
zabbix监控mysql性能
通过获取mysql状态值将这些状态值传递给服务器并绘制成图片,这样可以观察mysql的工作情况,通常需要获得状态变量有以下
com_update:mysql执行的更新个数 com_select:mysql执行的查询个数 com_insert:mysql执行插入的个数 com_delete:执行删除的个数 com_rollback:执行回滚的操作个数 bytes_received:接受的字节数 bytes_sent:发送的字节数 slow_queries:慢查询语句的个数1、创建mysql性能监控脚本
#!/bin/bash#create by zhengdazhi 2014.09.22mysql_dir=/usr/local/mysqlmysql=${mysql_dir}/bin/mysqlmysqladmin=${mysql_dir}/bin/mysqladminmysql_sock=/tmp/mysql.sockmysql_user=rootmysql_pwd=root args=1 if [ $# -ne $args ];then echo please input one arguement: fi case $1 in uptime) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock status|cut -f2 -d:|cut -f1 -dt` echo $result ;; com_update) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w com_update|cut -d| -f3` echo $result ;; slow_queries) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock status |cut -f5 -d:|cut -f1 -do` echo $result ;; com_select) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w com_select|cut -d| -f3` echo $result ;; com_rollback) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w com_rollback|cut -d| -f3` echo $result ;; questions) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock status|cut -f4 -d:|cut -f1 -ds` echo $result ;; com_insert) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w com_insert|cut -d| -f3` echo $result ;; com_delete) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w com_delete|cut -d| -f3` echo $result ;; com_commit) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w com_commit|cut -d| -f3` echo $result ;; bytes_sent) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w bytes_sent |cut -d| -f3` echo $result ;; bytes_received) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w bytes_received |cut -d| -f3` echo $result ;; com_begin) result=`${mysqladmin} -u${mysql_user} -p${mysql_pwd} -s $mysql_sock extended-status |grep -w com_begin|cut -d| -f3` echo $result ;; *) echo usage:$0(uptime|com_update|slow_queries|com_select|com_rollback|questions) ;; esac
2、修改客户端配置文件
查看zabbix自带的mysql监控模板
可以看出该模板是读取 mysql.status的键,因此在客户端配置文件中加入的自定义键名也应该是mysql.status
vim /usr/local/zabbix_agentd/etc/zabbix_agentd.conf#开启用户自定义配置unsafeuserparameters=1#添加mysql监控userparameter=mysql.status[*],/usr/local/zabbix_agent/bin/checkmysqlperformance.sh $1 $2
重启客户端
3、测试
[root@localhost bin]# ./zabbix_get -s 127.0.0.1 -k mysql.status[com_update]77503
4、将模板加入主机
