部署Zabbix监控之邮件报警

通过部署Zabbix监控可以简单的部署zabbix server端,这篇博文主要介绍如何部署zabbix agent端。前提是必须基于上述博文zabbix server的环境。

一、部署zabbix agent端

下载zabbix软件

[root@agent ~]# tar zxf zabbix-3.2.1.tar.gz  && cd zabbix-3.2.1/
[root@agent zabbix-3.2.1]#  ./configure --prefix=/usr/local/zabbix --enable-agent && make && make install
// --enable-agent :开启zabbix agent模式
[root@agent ~]# sed -i "s#BASEDIR=/usr/local#BASEDIR=/usr/local/zabbix#g" /etc/init.d/zabbix_agentd 
//编译启动脚本中指定zabbix的安装路径
[root@agent ~]# chmod +x /etc/init.d/zabbix_agentd 
[root@agent ~]# cd /usr/local/zabbix/etc/
[root@agent etc]# sed -i '/PidFile=/s/^#//'  zabbix_agentd.conf
[root@agent etc]# sed -i 's/Server=127.0.0.1/Server=192.168.1.10/g' zabbix_agentd.conf
[root@agent etc]# sed -i '/ListenPort=/s/^#//'  zabbix_agentd.conf
[root@agent etc]# sed -i 's/ServerActive=127.0.0.1/ServerActive=192.168.1.10/g' zabbix_agentd.conf
[root@agent etc]# sed -i 's/Hostname=Zabbix server/Hostname=192.168.1.8/g' zabbix_agentd.conf
[root@agent etc]# echo -e "Timeout=15" >> zabbix_agentd.conf
[root@agent etc]# echo -e "Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/" >> zabbix_agentd.conf
[root@agent etc]# egrep -v '^$|^#' zabbix_agentd.conf
//确保配置文件没有错误
PidFile=/tmp/zabbix_agentd.pid
LogFile=/tmp/zabbix_agentd.log
Server=192.168.1.10                  //指定zabbix server的IP地址(被动模式下)
ListenPort=10050                      //指定监听的端口
ServerActive=192.168.1.10       //指定zabbix server的IP地址(主动模式下)
Hostname=192.168.1.8             //指定的名字必须和web页面的host的名字一样
Timeout=15                               //超时时间
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/ 
[root@agent ~]# /etc/init.d/zabbix_agentd start             //启动zabbix服务
Reloading systemd:                                         [  确定  ]
Starting zabbix_agentd (via systemctl):                    [  确定  ]
[root@agent ~]# netstat -anpt | grep zabbix           //确认其监听端口
tcp        0      0 0.0.0.0:10050           0.0.0.0:*               LISTEN      9587/zabbix_agentd 

二、配置zabbix server的web页面可以监控到客户端主机

如图:
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警

至此在zabbix server提供的web页面中,已经可以监控到zabbix agent端的信息!

三、客户端部署Mysql服务

zabbix agent端可以使用yum的方式部署mysql服务,但是建议使用源码编译的方式,但是考虑到源码编译安装时间太长,所以提供一键式脚本安装mysql,与源码编译安装一致!对源码编译安装感兴趣的可以参考编译安装mysql

以下操作需在zabbix agent端进行配置!

[root@agent ~]# ls | grep mysql
mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz
mysql.sh
[root@agent ~]# sh mysql.sh 
Starting MySQL. SUCCESS! 
mysql: [Warning] Using a password on the command line interface can be insecure.
[root@agent ~]# cd /root/zabbix-3.2.1/conf/zabbix_agentd/
[root@agent zabbix_agentd]# cp userparameter_mysql.conf /usr/local/zabbix/etc/zabbix_agentd.conf.d/
//复制zabbix源码包自带的mysql模板文件
[root@agent zabbix_agentd]#  cd /usr/local/zabbix/etc/
[root@agent etc]# echo -e "[client]\nhost=192.168.1.8\nuser=test\npassword=123.com\nsocket=/usr/local/mysql/mysql.sock" > .my.cnf
[root@agent etc]# cat .my.cnf 
[client]
host=192.168.1.8          //指定mysql数据库IP地址
user=test                      //指定用于测试的用户
password=123.com           //用户对应的密码
socket=/usr/local/mysql/mysql.sock          //指定mysql.sock文件所在的路径(rpm安装的可以不用写)
[root@agent etc]# mysql -u root -p123              //脚本提供的mysql数据库root用户密码默认是123
mysql> grant all on *.* to test@'192.168.1.%' identified by '123.com';                //创建授权规则
[root@agent etc]# cd zabbix_agentd.conf.d/
[root@agent zabbix_agentd.conf.d]# sed -i 's#HOME=/var/lib/zabbix mysql#HOME=/usr/local/zabbix/etc/ /usr/local/mysql/bin/mysql#g' userparameter_mysql.conf 
//更改文件中zabbix的安装位置及mysql命令所在位置
[root@agent zabbix_agentd.conf.d]# /etc/init.d/zabbix_agentd restart
//重新加载配置文件

zabbix提供的模板文件修改后的内容,如图:
部署Zabbix监控之邮件报警
由于其复杂性,关于其内容先不做任何解释了!

zabbix server使用以下命令进行验证:

[root@zabbix ~]# zabbix_get -s 192.168.1.8 -p 10050 -k "mysql.status[Uptime]"
1662
//zabbix_get:获取数据
//-s:指定客户端的IP地址或域名
//-p:指定客户端的端口(默认情况下是10050)
//-k:指定需要获取的值
//有消息返回就表示正常

四、配置zabbix server可以监控mysql

如图:
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警

出现上述情况则表示mysql监控成功!

五、配置邮件报警

以上操作需在zabbix server端进行配置!

扫描二维码关注公众号,回复: 8472046 查看本文章
[root@zabbix ~]# yum install perl-Net-SSLeay perl-IO-Socket-SSL -y
//安装依赖支持邮件的加密传输
[root@zabbix ~]# tar zxf sendEmail-v1.56.tar.gz 
[root@zabbix ~]# cp sendEmail-v1.56/sendEmail /usr/local/bin/
[root@zabbix ~]# chown zabbix:zabbix /usr/local/bin/sendEmail
//使zabbix用户可以使用sendEmail这个命令
[root@zabbix ~]# vim /usr/local/bin/sendEmail
1906         if (! IO::Socket::SSL->start_SSL($SERVER)) {
//编辑这个脚本中的内容,修改为以上内容

在接下来的操作中,需要有自己邮箱的授权码,这里以QQ邮箱为例(163或新浪邮箱都是可以的),操作如如图:
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
部署Zabbix监控之邮件报警
配置完成后,编写以下脚本进行测试:

[root@zabbix ~]# cd /usr/local/zabbix/share/zabbix/alertscripts
[root@zabbix alertscripts]# vim mail.sh 
[root@zabbix alertscripts]# chmod +x mail.sh 

猜你喜欢

转载自blog.51cto.com/14157628/2465517