一、什么是zabbix及優缺點(對比cacti和nagios)
- 優點:基於兩款工具優點於一身並更強大,實現企業級分布式監控。
- 缺點:2.2版本帶寬占用大但是升級到2.4版本后更節省了帶寬資源,其它再無發現。
二、監控功能
- 設備:服務器,路由器,交換機
- 軟件:OS,網絡,應用程序
- 主機性能指標監控
- 故障監控: down機,服務不可用,主機不可達
三、工作原理
四、zabbix的組件及進程
五、zabbix監控環境中基本概念
六、在centos7.3上安裝zabbix4.0
#安裝mariadb10.3數據庫 [mariadb] name=MariaDB baseurl=http://mirrors.ustc.edu.cn/mariadb/yum/10.3/centos7-amd64/ gpgkey=http://mirrors.ustc.edu.cn/mariadb/yum/RPM-GPG-KEY-MariaDB gpgcheck=1 #安裝mariadb數據庫
yum install MariaDB
#安裝zabbix4.0的源 rpm -ivh https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-1.el7.noarch.rpm #安裝zabbix所需的組件 yum install zabbix-server-mysql zabbix-web-mysql zabbix-agent # mysql -uroot -proot mysql> create database zabbix character set utf8 collate utf8_bin; mysql> grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix'; mysql> quit; #導入zabbix服務器所需要的表和數據 zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -p zabbix #編輯文件/etc/zabbix/zabbix_server.conf DBPassword=zabbix #編輯文件設置時區/etc/httpd/conf.d/zabbix.conf php_value date.timezone Europe/Riga(打開注釋) #啟動服務和開機自啟 systemctl restart zabbix-server zabbix-agent httpd systemctl enable zabbix-server zabbix-agent httpd #瀏覽器訪問 http://server_ip/zabbix #有亂碼方塊的解決辦法 在windows下的C:\Windows\Fonts下找到宋體字文件simsun.ttc 上傳到linux服務器中 cd /usr/share/zabbix/fonts #將原來的字體備份 mv graphfont.ttf graphfont.ttf.bak #把windows中的字體改名為graphfont.ttf mv simsun.ttc graphfont.ttf
一、關閉sendmail或者postfix
service sendmail stop #關閉
chkconfig sendmail off #禁止開機啟動
service postfix stop
chkconfig postfix off
備注:
使用外部郵箱賬號時,不需要啟動sendmail或者postfix
如果在sendmail或者postfix啟動的同時使用外部郵箱發送報警郵件,首先會讀取外部郵箱
配置信息。
二、安裝郵件發送工具mailx
下載mailx:
yum install mailx
whereis mailx #查看安裝路徑
mailx -V #查看版本信息
三、配置Zabbix服務端外部郵箱
vi /etc/mail.rc #編輯,添加以下信息
set from=xxx@163.com smtp=smtp.163.com
set smtp-auth-user=xxx@163.com smtp-auth-password=123456
set smtp-auth=login
:wq! #保存退出
echo "zabbix test mail" |mail -s "zabbix" yyy@163.com
#測試發送郵件,標題zabbix,郵件內容:zabbix test mail,發送到的郵箱:yyy@163.com
#這時候,郵箱yyy@163.com會收到來自xxx@163.com的測試郵件
四、配置Zabbix服務端郵件報警
1、打開Zabbix
2、設置Zabbix用戶報警郵箱地址
3、設置Zabbix觸發報警的動作
主題:
Problem: {EVENT.NAME}故障{TRIGGER.STATUS},服務器:{HOSTNAME1}發生: {TRIGGER.NAME}故障!
內容:
告警主機:{HOSTNAME1}
告警時間:{EVENT.DATE} {EVENT.TIME}
告警等級:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警項目:{TRIGGER.KEY1}
問題詳情:{ITEM.NAME}:{ITEM.VALUE}
當前狀態:{TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID:{EVENT.ID}
恢復主題:
恢復{TRIGGER.STATUS}, 服務器:{HOSTNAME1}: {TRIGGER.NAME}已恢復!
恢復信息:
告警主機:{HOSTNAME1}
告警時間:{EVENT.DATE} {EVENT.TIME}
告警等級:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警項目:{TRIGGER.KEY1}
問題詳情:{ITEM.NAME}:{ITEM.VALUE}
當前狀態:{TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID:{EVENT.ID}
已啟用:打鈎
切換到操作選項
新的
操作類型:送出信息
送到用戶:添加
默認信息:打鈎
選擇用戶:Admin
選擇
僅送到:Sendmail
存檔
4、添加Zabbix服務端郵件發送腳本
cd /usr/lib/zabbix/alertscripts #進入腳本存放目錄
vi sendmail.sh #編輯,添加以下代碼
#!/usr/bin/sh echo 'start' >> /tmp/zabbix.log messages=`echo $3 | tr '\r\n' '\n'` subject=`echo $2 | tr '\r\n' '\n'` echo "${messages}" | mail -s "${subject}" $1 echo "end" >> /tmp/zabbix.log
:wq! #保存退出
chown zabbix.zabbix sendmail.sh
chown zabbix.zabbix /tmp/zabbix.log
#設置腳本所有者為zabbix用戶
chmod +x sendmail.sh
#設置腳本執行權限
五、測試Zabbix報警
關閉Zabbix客戶端服務
service zabbix_agentd stop
查看xxx@163.com郵箱,會收到報警郵件
再開啟Zabbix客戶端服務
service zabbix_agentd start
查看xxx@163.com郵箱,會收到恢復郵件
自動發現
點擊配置--->自動發現
創建自動發現的規則
然后就可以在檢測自動發現里看到掃描出來的主機了
如果要監控起來需要添加自動注冊,點擊配置--->動作
zabbix監控mysql數據庫
在客戶端的zabbix配置文件中添加HOME=/etc/zabbix/ mysqladmin ping | grep -c alive
proxy配置
create database zabbix_proxy character set utf8 collate utf8_bin; grant all privileges on zabbix_proxy.* to zabbix@localhost identified by 'zabbix'; zcat /usr/share/doc/zabbix-proxy-mysql-4.0.6/schema.sql.gz | mysql -uzabbix -pzabbix zabbix_proxy vim /etc/zabbix/zabbix_proxy.conf Server=192.168.254.61(zabbix server的ip地址) Hostname=zabbix-proxy(本機的主機名字) DBName=zabbix_proxy(數據庫名字) DBUser=zabbix(數據庫用戶名) DBPassword=zabbix(數據庫密碼) service zabbix-proxy restart
agent端
Server=192.168.254.62 ServerActive=192.168.254.62 HostnameItem=system.hostname
自定義監控
UnsafeUserParameters=1 UserParameter=proc.mysql,ps -ef|grep mysql|wc -l
測試命令
yum install zabbix-get zabbix_get -s 127.0.0.1 -p 10050 -k "proc.mysql"