搭建zabbix監控以及郵件報警的超級詳細教學

一、zabbix

1.1 簡介

zabbix 是一款開源的功能強大的分佈式監控系統,一個基於WEB界面的提供分佈式系統監視以及網絡監視功能的企業級的開源解決方案。

zabbix server可以通過SNMP,zabbix agent,ping,端口監視等方法提供對遠程服務器/網絡狀態的監視。

zabbix是由2部分構成,分別是zabbix server(監控端)與zabbix agent(被監控端)。

1.2 zabbix主要功能

  • CPU負荷
  • 內存使用
  • 磁盤使用
  • 網絡狀況
  • 端口監視
  • 日志監視

1.3 zabbix的主要特點

  • 安裝與配置簡單,學習成本低
  • 支持多語言(包括中文)
  • 免費開源
  • 自動發現服務器與網絡設備
  • 分佈式監視以及WEB集中管理功能
  • 可以無agent監視
  • 用戶安全認證和柔軟的授權方式
  • 通過WEB界面設置或查看監視結果
  • email等通知功能

1.4 zabbix組件

  • zabbix server:負責接收agent發送的報告信息的核心組件,所有配置,統計數據及操作數據均由其組織進行
  • zabbix database:用戶存儲所有配置信息,以及存儲由zabbix server收集到的數據
  • zabbix web:zabbix的interface接口,通常與Server運行在同一臺主機上
  • zabbix agent:部署在被監控主機上,負責收集本地數據發往server端或proxy端
  • zabbix proxy:常用於分佈監控環境中,代理Server收集部分被監控的監控數據並統一發往Server端(通常大於500臺主機才需要使用)

1.5 zabbix原理

zabbix agent安裝在被監控的主機上,負責定期收集被監控端的本地各項數據,並發送至zabbix server端,zabbix server收到數據,將數據存儲到數據庫( zabbix database)中,用戶基於zabbix web的可視化界面可以看到前端數據圖像。當zabbix監控某個具體的項目時,該項目會設置一個觸發器閾值,當被監控的指標超過該觸發器設定的閾值,會進行一些必要的動作,動作包括:發送信息(郵件、微信、短信)、發送命令(SHELL 命令、Reboot、Restart、Install等)。

二、基於LNMP環境搭建zabbix監控

zabbix server(監控端)

2.1 安裝nginx

systemctl stop firewalld.service           #關閉防火墻及核心安全機制
setenforce 0

vim /etc/yum.repos.d/nginx.repo        #創建nginx的yum倉庫

[nginx]
name=nginx
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1

yum clean all
yum list

yum install -y nginx

systemctl start nginx
systemctl enable nginx
netstat -natp | grep 80

2.2 安裝mariadb

yum -y install mariadb-server mariadb
systemctl start mariadb.service
systemctl enable mariadb.service
netstat -natp | grep 3306

mysql_secure_installation
Enter current password for root (enter for none):			#回車
Set root password? [Y/n]									#Y
New password:												#123456
Re-enter new password:										#123456
Remove anonymous users?										#n
Disallow root login remotely?								#n
Remove test database and access to it?						#n
Reload privilege tables now?								#Y

登錄驗證

mysql -u root -p123456
exit

2.3 安裝php

yum -y install epel-release.noarch
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm		#yum源的建立
yum install -y php72w php72w-devel php72w-fpm php72w-gd php72w-mbstring php72w-mysql			#安裝環境依賴包
php -v					#查看版本

2.4 修改php-fpm配置文件

vim /etc/php-fpm.d/www.conf

user = nginx	     #第8行
group = nginx	     #第10行

2.5 修改nginx配置文件支持PHP並修改php配置文件

    index  index.php index.html index.htm;		#第10行添加index.php
 
    location ~ \.php$ {                                                  #配置php模塊,去掉註釋
        root           /usr/share/nginx/html;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }

vim /etc/php.ini

short_open_tag = On    		 		 #202行修改,支持php短標簽
expose_php  = Off 		 			 #359行修改,隱藏php版本

##為PHP兼容zabbix進行修改,優化配置要求
max_execution_time = 300				 #368行修改,執行時間
max_input_time = 300					 #378行修改,接收數據等待時向
memory_limit = 128M 					 #389行,每個腳本占用內存
post_max_size = 16M 					 #656行修改,POST數據大小
upload_max_filesize = 2M 				 #799行,下載文件大小
always_populate_raw_post_data = -1   	 #800行添加,可以用$HTTP_RAW_POST DATA
date.timezone = Asia/Shanghai 	         #877行取消註釋並添加時區

開啟服務

systemctl start php-fpm
systemctl enable php-fpm
netstat -natp | grep 9000

systemctl restart nginx

2.6 測試網頁

vim /usr/share/nginx/html/info.php

<?php
     phpinfo();
?>

http://192.168.153.40/info.php

2.7 測試連接數據庫

vim /usr/share/nginx/html/test.php

<?php
 $link=mysqli_connect('127.0.0.1','root','123456');
 if ($link) echo "數據庫連接成功!";
 else echo "數據庫連接失敗~";
?>

http://192.168.153.40/test.php

2.8 建立數據庫及用戶並且授權

mysql -uroot -p123456

create database zabbix character set utf8 collate utf8_bin;

grant all privileges ON *.* TO 'zabbix'@'%' IDENTIFIED BY 'admin123';

flush privileges;

exit

2.9 測試連接zabbix數據庫

vim /usr/share/nginx/html/zabbix.php

<?php
  $link=mysqli_connect('127.0.0.1','zabbix' ,'admin123' );
  if ($link) echo "zabbix數據庫連接成功 !";
  else echo "zabbix數據庫連接失敗 !";
?>

http://192.168.153.40/zabbix.php

註:在連接zabbix數據庫失敗的解決辦法,刪除用戶名為空的主機即可

mysql -uroot -p123456

select user,host from mysql.user;
+--------+-----------+
| user   | host      |
+--------+-----------+
| zabbix | %         |
| root   | 127.0.0.1 |
| root   | ::1       |
|        | localhost |
| root   | localhost |
|        | wt        |
| root   | wt        |
+--------+-----------+
7 rows in set (0.00 sec)

drop user ''@localhost;
drop user ''@wt;
exit

刷新重連

2.10 zabbix server部署

2.10.1下載zabbix源並安裝

rpm -i https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-1.el7.noarch.rpm
yum -y install zabbix-server-mysql zabbix-web-mysql zabbix-agent

2.10.2 導入數據庫腳本並驗證

zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -padmin123 zabbix

mysql -u zabbix -padmin123
use zabbix;
show tables;
exit

2.10.3 修改zabbix配置文件

vim /etc/zabbix/zabbix_server.conf
LogFile=/var/log/zabbix/zabbix_server.log          #38行
LogFileSize=0        #49行
PidFile=/var/run/zabbix/zabbix_server.pid         #72行
SocketDir=/var/run/zabbix       #82行
DBHost=localhost                #91行,取消註釋
DBName=zabbix                   #100行
DBUser=zabbix                   #116行
DBPassword=admin123             #124行,取消註釋,zabbix數據庫的密碼
SNMPTrapperFile=/var/log/snmptrap/snmptrap.log     #356行
Timeout=4                                          #473行
AlertScriptsPath=/usr/lib/zabbix/alertscripts      #516行
ExternalScripts=/usr/lib/zabbix/externalscripts    #527行
LogSlowQueries=3000                                #563行
vim /etc/httpd/conf.d/zabbix.conf

php_value date.timezone Asia/Shanghai       #20行,修改時區

2.10.4授權

cp -r /usr/share/zabbix/ /usr/share/nginx/html/
chown -R zabbix:zabbix /etc/zabbix/
chown -R zabbix:zabbix /usr/share/nginx/
chown -R zabbix:zabbix /usr/lib/zabbix/
chmod -R 755 /etc/zabbix/web/
chmod -R 777 /var/lib/php/session/

2.10.5 開啟服務

systemctl start zabbix-server
systemctl enable zabbix-server
systemctl start zabbix-agent.service
systemctl enable zabbix-agent.service
netstat -ntap | grep 10051
systemctl restart php-fpm.service
systemctl restart nginx

http://192.168.153.40/zabbix/setup.php

2.10.6 瀏覽器訪問測試

http://192.168.153.40/zabbix
賬號:Admin    密碼:zabbix

zabbix-agent端

①關閉防火墻和核心防護機制

systemctl stop firewalld
setenforce 0

②部署zabbix-agent

rpm -i https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-1.el7.noarch.rpm
yum install -y zabbix-agent

③修改配置文件

PidFile=/var/run/zabbix/zabbix_agentd.pid   #13行
LogFile=/var/log/zabbix/zabbix_agentd.log   #32行
LogFileSize=0                               #43行
Server=192.168.153.40						#98行修改,指向監控服務器
ServerActive=192.168.153.40					#139行修改,指向監控服務器
Hostname=test                			    #150行,指定名稱
Include=/etc/zabbix/zabbix_agentd.d/*.conf  #268行

④開啟服務並檢查端口

systemctl start zabbix-agent
systemctl enable zabbix-agent
netstat -natp | grep zabbix				#查看10050端口

監控驗證(監控端)

如何切換成中文界面

添加被監控的主機

在zabbix圖形頁面——配置——主機——創建主機(定義主機名稱、添加群組、填寫被監控端主機IP地址)——模板——選定要監控的模板(httpd sshd服務)——選擇——添加(添加連接模板)——添加(添加主機)

三、郵件報警

3.1 zabbix監控端配置

yum -y install mailx

vim /etc/mail.rc
'//末尾添加'
set from=郵箱
set smtp=smtp.qq.com
set smtp-auth-user=郵箱
set smtp-auth-password=郵箱授權碼
set smtp-auth=login

測試下郵件是否可以發送

echo "hello tomorrow" | mail -s "test" 郵箱

編寫郵件腳本

cd /usr/lib/zabbix/alertscripts
vim mailx.sh
#!/bin/bash
#send mail
messages=`echo $3 | tr '\r\n' '\n'`
subject=`echo $2 | tr '\r\n' '\n'`
echo "${messages}" | mail -s "${subject}" $1 >>/tmp/mailx.log 2>&1

創建日志文件並修改權限並測試

touch /tmp/mailx.log
chown -R zabbix.zabbix  /tmp/mailx.log 
chmod +x mailx.sh 
chown -R zabbix.zabbix /usr/lib/zabbix/
sh mailx.sh 郵箱 zabbix "this is test"

3.2 web網頁配置

3.2.1 添加報警媒介

管理 > 報警媒介類型 > 創建媒體類型

名稱自定義,後面會用到
類型選擇腳本
腳本名稱是之前編輯的腳本名稱
腳本的三個參數:
{ALERT.SENDTO}
{ALERT.SUBJECT}
{ALERT.MESSAGE}

3.2.2 添加用戶

管理 > 用戶 > 點擊Admin > 報警媒介 > 添加
類型選擇之前自定義的名稱
收件人填自己郵箱
點擊添加
點擊更新

3.2.3 創建動作

配置 > 動作 >刪除默認的動作 > 創建動作 > 刪除默認 > 創建動作



添加執行操作

默認標題   {TRIGGER.STATUS}:{TRIGGER.NAME}
消息內容   告警主機:{HOST.NAME}
          告警IP:{HOST.IP}
          告警時間:{EVENT.DATE}-{EVENT.TIME}
          告警等級:{TRIGGER.SEVERITY}
          告警信息:{TRIGGER.NAME}-{ITEM.VALUE}
          事件ID:{EVENT.ID}

添加恢復操作

除瞭消息內容的模板,其他和上一步基本一致

默認標題   {TRIGGER.STATUS}:{TRIGGER.NAME}

消息內容   恢復主機:{HOST.NAME}
          恢復IP:{HOST.IP}
          恢復時間:{EVENT.DATE}-{EVENT.TIME}
          恢復等級:{TRIGGER.SEVERITY}
          恢復信息:{TRIGGER.NAME}-{ITEM.VALUE}
          事件ID:{EVENT.ID}

最後再確認一下操作是不是都添加完成瞭,如果沒完成是不會發送郵件的!!

3.2.4 測試

被監控端停止sshd服務

systemctl stop sshd

可以看到郵件已經發送過來瞭,並且儀表板的問題界面開始閃爍

重新開啟服務後同樣會有郵件發來

systemctl start sshd

總結 

到此這篇關於搭建zabbix監控以及郵件報警的文章就介紹到這瞭,更多相關搭建zabbix監控及郵件報警內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: