1、什麼是zabbix及優缺點(對比cacti和nagios)
- 優勢:基於兩款工具優勢於一身並更強大,實現企業級分佈式監控。
- 缺點:2.2版本帶寬佔用大可是升級到2.4版本後更節省了帶寬資源,其它再無發現。
2、監控功能
- 設備:服務器,路由器,交換機
- 軟件:OS,網絡,應用程序
- 主機性能指標監控
- 故障監控: down機,服務不可用,主機不可達
3、工做原理
4、zabbix的組件及進程
5、zabbix監控環境中基本概念
6、在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
1、關閉sendmail或者postfix
service sendmail stop #關閉php
chkconfig sendmail off #禁止開機啓動html
service postfix stop前端
chkconfig postfix offnode
備註:mysql
使用外部郵箱帳號時,不須要啓動sendmail或者postfixlinux
若是在sendmail或者postfix啓動的同時使用外部郵箱發送報警郵件,首先會讀取外部郵箱ios
配置信息。web
2、安裝郵件發送工具mailx
下載mailx:sql
yum install mailx數據庫
whereis mailx #查看安裝路徑
mailx -V #查看版本信息
3、配置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的測試郵件
4、配置Zabbix服務端郵件報警
一、打開Zabbix
二、設置Zabbix用戶報警郵箱地址
三、設置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
存檔
四、添加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
#設置腳本執行權限
5、測試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"