zabbix基本操作

来源:https://www.cnblogs.com/1naonao/archive/2019/12/18/12061615.html
-Advertisement-
Play Games

第一章 監控知識基本概述 1.為什麼要使用監控 1.對系統不間斷實時監控 2.實時反饋系統當前狀態 3.保證服務可靠性安全性 4.保證業務持續穩定運行 2.如何進行監控,比如我們需要監控磁碟的使用率 1.如何查看磁碟使用率 df h 2.監控磁碟的那些指標 block、 inode 3.如何獲取具體 ...


第一章 監控知識基本概述

1.為什麼要使用監控

1.對系統不間斷實時監控
2.實時反饋系統當前狀態
3.保證服務可靠性安全性
4.保證業務持續穩定運行

2.如何進行監控,比如我們需要監控磁碟的使用率

1.如何查看磁碟使用率 df -h
2.監控磁碟的那些指標 block、 inode
3.如何獲取具體的信息 df -h|awk '///{print(NF-1)}'
4.獲取的數值到達多少報警 80%

3.流行的監控工具

1.Zabbix
2.Lepus(天兔)資料庫監控系統
3.Open-Falcon 小米
4.Prometheus(普羅米修斯, Docker、 K8s)

4.如果去到一家新公司,如何入手監控

1.硬體監控 路由器、交換機、防火牆
2.系統監控 CPU、記憶體、磁碟、網路、進程、 TCP
3.服務監控 nginx、 php、 tomcat、 redis、 memcache、 mysql
4.WEB 監控 請求時間、響應時間、載入時間、
5.日誌監控 ELk(收集、存儲、分析、展示) 日誌易
6.安全監控 Firewalld、 WAF(Nginx+lua)、安全寶、牛盾雲、安全狗
7.網路監控 smokeping 多機房
8.業務監控 活動引入多少流量、產生多少註冊量、帶來多大價值

第二章 單機時代如何監控

CPU 監控命令: w、 top、 htop、 glances

%Cpu(s): 0.3 us, 0.3 sy, 0.0 ni, 99.3 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
us 用戶態: 跟用戶的操作有關 35%
sy 系統態: 跟內核的處理有關 60%
id CPU 空閑:

記憶體監控命令: free

[root@m01 ~]# free -h
              total        used        free      shared  buff/cache   available
Mem:           977M        105M        724M        6.6M        148M        729M
Swap:          1.0G          0B        1.0G

磁碟監控命令: df、 iotop

Device: tps kB_read/s kB_wrtn/s kB_read kB_wrtn
sda 0.80 25.32 33.36 221034 291193
設備名 每秒傳輸次數 每秒讀大小 每秒寫大小 讀的總大小 寫的總大小

網路監控命令: ifconfig、 route、 glances、 iftop、 nethogs、 netstat

單位換算
Mbps 100Mbps/8
MB 12MB
iftop 中間的<= =>這兩個左右箭頭,表示的是流量的方向。
TX:發送流量、 RX:接收流量、 TOTAL:總流量
#查看 TCP11 中狀態
netstat -an|grep ESTABLISHED
netstat -rn # 查看路由信息
netstat -lntup

2.隨著時間的推移,用戶不斷的增多,服務隨時可能扛不住會被 oom(out of memory),當系統記憶體不足的時候,會
觸發 oom
1.當系統記憶體不足的時候就會大量使用 swap
2.當系統大量使用 swap 的時候,系統會特別卡
註意: 有時可能記憶體還有剩餘 300Mb-500Mb,但會發現 swap 依然被使用

[root@ZabbixServer ~]# dd if=/dev/zero of=/dev/null bs=800M
[root@ZabbixServer ~]# tail -f /var/log/messages
Out of memory: Kill process 2227 (dd) score 778 or sacrifice child
Killed process 2227 (dd) total-vm:906724kB, anon-rss:798820kB, file-rss:0kB

3.那單機時代,如何使用 shell 腳本來實現伺服器的監控
需求: 每隔 1 分鐘監控一次記憶體,當你的可用記憶體低於 100m,發郵件報警,要求顯示剩餘記憶體
1.怎麼獲取記憶體可用的值 free -m|awk '/^Mem/{print $NF}'
2.獲取到記憶體可用的值如何和設定的閾值進行比較
3.比較如果大於 100m 則不處理,如果小於 100 則報警
4.如何每隔 1 分鐘執行一次

[root@ZabbixServer ~]# cat free.sh
#!/usr/bin/bash
HostName=$(hostname)_$(hostname -i)
Date=$(date +%F)
while true;do
Free=$(free -m|awk '/^Mem/{print $NF}')
if [ $Free -le 100 ];then
echo "$Date: $HostName Mem Is < ${Free}MB"
fi
sleep 5
done

第三章 zabbix 監控快速安裝

1.配置zabbix倉庫

[root@m01 ~]#rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-1.el7.noarch.rpm

2.安裝 Zabbix 程式包,以及 MySQL、 Zabbix-agent

[root@m01 ~]# yum install -y zabbix-server-mysql zabbix-web-mysql zabbix-agent mariadb-server
[root@m01 ~]# systemctl start mariadb.service && systemctl enable mariadb.service

3.創建 Zabbix 資料庫以及用戶

[root@m01 ~]# mysqladmin password 123456
[root@m01 ~]# mysql -uroot -p123456
MariaDB [(none)]> create database zabbix character set utf8 collate utf8_bin;
MariaDB [(none)]> grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';
MariaDB [(none)]> flush privileges;

4.導入 Zabbix 數據至資料庫中

[root@m01 ~]# zcat /usr/share/doc/zabbix-server-mysql-4.0.11/create.sql.gz | mysql -uzabbix -pzabbix zabbix

5.編輯/etc/zabbix/zabbix_server.conf 文件,修改資料庫配置

[root@m01 ~]# grep "^[a-Z]" /etc/zabbix/zabbix_server.conf 
...............
DBHost=localhost
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
...............

6.啟動 Zabbix 服務進程,並加入開機自啟

[root@m01 ~]# systemctl start zabbix-server.service 
[root@m01 ~]# systemctl enable zabbix-server.service

7.配置 Apache 的配置文件/etc/httpd/conf.d/zabbix.conf,修改時區

[root@m01 ~]# grep "Shanghai" /etc/httpd/conf.d/zabbix.conf 
        php_value date.timezone Asia/Shanghai

8.重啟 Apache Web 伺服器

[root@m01 ~]# systemctl start httpd

第四章 WEB安裝步驟

1.瀏覽器打開地址:http://10.0.1.61/zabbix/setup.php

img

2.檢查依賴項是否存在異常

img

3.配置zabbix連接資料庫

img

4.配置 ZabbixServer 伺服器的信息

img

5.最終確認檢查

img

6.安裝成功

提示已成功地安裝了 Zabbix 前端。配置文件/etc/zabbix/web/zabbix.conf.php 被創建。

img

7.登陸zabbix

預設登陸 ZabbixWeb 的用戶名 Admin,密碼 zabbix

img

8.調整字元集為中文

img

img

#解除問題
systemctl start zabbix-agent

9.修複中文亂碼

打開圖形之後會發現語言為亂碼,原因是缺少字體

img

解決方法:安裝字體並替換現有字體

[root@m01 ~]# yum install wqy-microhei-fonts -y
[root@m01 ~]# cp /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /usr/share/zabbix/assets/fonts/graphfont.ttf

再次刷新發現已經變成中文了

img

第五章 Zabbix 監控基礎架構

zabbix-agent(數據採集)—>zabbix-server(數據分析|報警)—> 資料庫(數據存儲)<—zabbix web(數據展示)

img

第六章 zabbix 快速監控主機

1.安裝zabbix-agent

[root@web01 ~]# rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/4.0/rhel/7/x86_64/zabbix-agent-4.0.11-1.el7.x86_64.rpm

2.配置zabbix-agent

[root@web01 ~]# grep "^[a-Z]" /etc/zabbix/zabbix_agentd.conf    
PidFile=/var/run/zabbix/zabbix_agentd.pid
LogFile=/var/log/zabbix/zabbix_agentd.log
LogFileSize=0
Server=10.0.1.61
ServerActive=127.0.0.1
Hostname=Zabbix server
Include=/etc/zabbix/zabbix_agentd.d/*.conf

3.啟動zabbix-agent並檢查

[root@web01 ~]# systemctl start zabbix-agent.service 
[root@web01 ~]# systemctl enable zabbix-agent.service
[root@web01 ~]# netstat -lntup|grep 10050
tcp        0      0 0.0.0.0:10050           0.0.0.0:*               LISTEN      10351/zabbix_agentd 
tcp6       0      0 :::10050                :::*                    LISTEN      10351/zabbix_agentd 

4.zabbix-web界面,添加主機

img

img

img

補充

辭彙表

zabbix-server :負責接收agent的數據,分析並存入mysql
zabbix-agent :負責採集客戶端的數據併發送給zabbix-server
zabbix-web : 負責展示,過濾,配置監控項,觸發器,報警媒介
mysql :實際負責存儲數據
監控項 :每一個實際的監控內容
自定義監控項 :預設監控模板沒有的監控內容,需要自己自定義的監控
應用集 : 把監控項分類劃分
觸發器 :監控項的報警閾值
報警媒介 :報警的方式 微信 郵件
圖形 :監控項歷史記錄的趨勢圖,多個監控項可以一起展示
聚合圖形 :多個圖形可以組合成一個更大的圖形
模板 :

第七章 自定義監控主機小試身手

自定義監控tcp(一)

1.項目需求
監控當前有幾個用戶是登錄狀態
如果用同時線上的用戶超過3個就報警

2.任務拆解
shell命令實現:
who|wc -l

3.編寫自定義監控項
cat /etc/zabbix/zabbix_agentd.d/who_num.conf 
UserParameter=who_num,who|wc -l

4.重啟zabbix-agent
systemctl restart zabbix-agent

5.zabbix服務端測試能否取到自定義監控項的值
註意!在服務端安裝
rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/4.0/rhel/7/x86_64/zabbix-get-4.0.11-1.el7.x86_64.rpm
zabbix_get -s 10.0.0.7 -k who_num

6.web頁面添加內容

自定義監控狀態(二)

1.監控需求

監控TCP11種狀態集

2.命令行實現

netstat -antp|awk 'NR>1{print $6}'|grep LISTEN|wc -l
netstat -antp|awk 'NR>1{print $6}'|grep TIME_WAIT|wc -l
netstat -antp|awk 'NR>1{print $6}'|grep ESTABLISHED|wc -l

3.編寫zabbix監控文件(傳參形式)

vim /etc/zabbix/zabbix_agentd.d
UserParameter=LISTEN,netstat -ant|awk 'NR>1{print $6}'|grep LISTEN|wc -l
UserParameter=TIME_WAIT,netstat -ant|awk 'NR>1{print $6}'|grep TIME_WAIT|wc -l
UserParameter=ESTABLISHED,netstat -ant|awk 'NR>1{print $6}'|grep ESTABLISHED|wc -l
systemctl restart zabbix-agent

4.server端進行測試

[root@m01 ~]# rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/4.0/rhel/7/x86_64/zabbix-get-4.0.11-1.el7.x86_64.rpm
# [root@m01 ~]# yum install zabbix-get.x86_64 -y 

zabbix_get -s 10.0.0.7 -k LISTEN
zabbix_get -s 10.0.0.7 -k TIME_WAIT
zabbix_get -s 10.0.0.7 -k ESTABLISHED

方法二:優化

1.多個監控項合併成一條命令的配置文件
cat >/etc/zabbix/zabbix_agentd.d/TCP.conf<<EOF
UserParameter=TCP_[*],netstat -ant|awk 'NR>1{print \$6}'|grep \$1|wc -l
EOF

2.重啟客戶端
systemctl restart zabbix_agent

3.服務端測試
zabbix_get -s 10.0.0.7 -k TCP_[LISTEN]
zabbix_get -s 10.0.0.7 -k TCP_[TIME_WAIT]

4.web頁面添加
配置-->主機-->監控項-->新加監控項-->名稱:TCP_LISTEN 鍵值:TCP_[LISTEN] 應用集:TCP
其他的監控項克隆

5.web端添加

img

img

6.克隆監控項

由於TCP有多種狀態,需要添加多個監控項,我們可以使用克隆快速達到創建的效果

img

img

img

其他的狀態依次添加即可

7.創建圖形

img

8.查看圖形

img

9.設置觸發器

img

img

img

img

第八章 郵件報警

1.定義發件人

img

img

2.定義收件人

img

img

3.自定義報警內容

配置>>>動作>>>操作>>>恢復操作

img

定製報警內容:
https://www.zabbix.com/documentation/4.0/zh/manual/appendix/macros/supported_by_location
參考博客

https://www.cnblogs.com/bixiaoyu/p/7302541.html

發送警告

報警郵件標題可以使用預設信息,亦可使用如下中文報警內容
名稱:Action-Email
預設標題:故障{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}

第九章 微信報警

1.查看配置文件里的腳本目錄路徑

[root@m01 ~]# grep "^AlertScriptsPath" /etc/zabbix/zabbix_server.conf
AlertScriptsPath=/usr/lib/zabbix/alertscripts

3.配置微信企業號
AgentId:1000008
Secret: 6h3MVlvmjqN-8rKz4V84OPMB5cp0PPJPlKR0ny9kt6U
corpid: wwd26fdfb9940e7efa

4.web頁面配置
{ALERT.SENDTO}
{ALERT.SUBJECT}
{ALERT.MESSAGE}

5.配置微信腳本修改參數

6.web頁面添加

2.將weixin.py放在zabbix特定目錄

[root@m01 /usr/lib/zabbix/alertscripts]# ll
總用量 4
-rwxr-xr-x 1 root root 1344 8月   7 21:58 weixin.py

3.配置發信人

img

img

4.配置收信人

img

5.登陸企業微信公眾號添加賬戶

https://work.weixin.qq.com/wework_admin/loginpage_wx
1.登陸後在企業號上新建應用

img

2.上傳logo,填寫應用名稱 ,應用介紹等

img

3.查看啟動應用

同時會生成應用的AgentId以及Secret,這個在後面步驟會有用

img

4.介面調用測試

http://work.weixin.qq.com/api/devtools/devtool.php

img

這裡的corpid為公司ID

img

Corpsecret就是剛纔創建應用生成的Secrt,確認沒問題填寫進去然後下一步

如果沒問題會顯示200狀態碼

img

6.添加成員

img

7.關註公眾號

img

8.查看自己的賬號

img

9.修改腳本里的信息(一個人)

[root@m01 /usr/lib/zabbix/alertscripts]# cat weixin.py 
..............
corpid='微信企業號corpid'
appsecret='應用的Secret'
agentid=應用的id
..............

腳本

#!/usr/bin/env python

import requests
import sys
import os
import json
import logging

logging.basicConfig(level = logging.DEBUG, format = '%(asctime)s, %(filename)s, %(levelname)s, %(message)s',
                datefmt = '%a, %d %b %Y %H:%M:%S',
                filename = os.path.join('/tmp','weixin.log'),
                filemode = 'a')
corpid='wwd26fdfb9940e7efa'
appsecret='6h3MVlvmjqN-8rKz4V84OPMB5cp0PPJPlKR0ny9kt6U'
agentid=1000008

token_url='https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=' + corpid + '&corpsecret=' + appsecret
req=requests.get(token_url)
accesstoken=req.json()['access_token']

msgsend_url='https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=' + accesstoken

touser=sys.argv[1]
subject=sys.argv[2]
#toparty='3|4|5|6'
message=sys.argv[2] + "\n\n" +sys.argv[3]

params={
        "touser": touser,
      # "toparty": toparty,


    "msgtype": "text",
    "agentid": agentid,
    "text": {
            "content": message
    },
    "safe":0
}

req=requests.post(msgsend_url, data=json.dumps(params))

logging.info('sendto:' + touser + ';;subject:' + subject + ';;message:' + message) 

10.發信測試

[root@m01 /usr/lib/zabbix/alertscripts]# python  weixin.py  你的賬號  '發信測試'  ‘微信測試消息’

11.微信號上查看

img

12.發送到整個微信組

雖然我們實現了發送到單個用戶的功能,但是如果我們的用戶比較多,這樣還是麻煩的,不過我們可以發送到整個組,其實腳本里已經預留好了配置,只不過預設註釋了。
將腳本修改為以下內容,註釋掉用戶,打開組設置

#!/usr/bin/env python

import requests
import sys
import os
import json
import logging

logging.basicConfig(level = logging.DEBUG, format = '%(asctime)s, %(filename)s, %(levelname)s, %(message)s',
                datefmt = '%a, %d %b %Y %H:%M:%S',
                filename = os.path.join('/tmp','weixin.log'),
                filemode = 'a')
corpid='wwd26fdfb9940e7efa'
appsecret='Btg89FnZfMu0k7l6b4iagmAR5Z9TCgKknYbx-SMQvmg'
agentid=1000005

token_url='https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=' + corpid + '&corpsecret=' + appsecret
req=requests.get(token_url)
accesstoken=req.json()['access_token']

msgsend_url='https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=' + accesstoken

#touser=sys.argv[1]
toparty=sys.argv[1]
subject=sys.argv[2]
message=sys.argv[2] + "\n\n" +sys.argv[3]

params={
        #"touser": touser,
        "toparty": toparty,
        "msgtype": "text",
        "agentid": agentid,
        "text": {
                "content": message
        },
        "safe":0
}

req=requests.post(msgsend_url, data=json.dumps(params))

logging.info('sendto:' + toparty + ';;subject:' + subject + ';;message:' + message)                                                                              

12.隨機發送到指定用戶玩笑腳本

#!/bin/bash 
num=$(echo $(($RANDOM%28+1)))
name=$(sed -n "${num}p" name.txt)
ok_boy=$(grep -v "${name}" name.txt)

for ok in ${ok_boy}
do
  python  weixin.py ${ok}  "$1"  "$2"
done



[root@web02 ~]# cat neigui.sh 
#!/bin/bash 
num=$(echo $(($RANDOM % 37 + 1)))
neigui=$(sed -n "${num}p" name.txt)
pc=$(sed "${num}d" name.txt > pc.txt)

for i in $(cat pc.txt)
do
  python  weixin.py ${i} '有內鬼,終止交易!'  "內鬼是: ${neigui}"
done
echo "內鬼是:${neigui}"


第十章 自定義模版

1.監控TCP11種狀態

編寫zabbix配置文件

[root@web01 /etc/zabbix/zabbix_agentd.d]# cat zbx_tcp.conf 
UserParameter=ESTABLISHED,netstat -ant|grep  -c 'ESTABLISHED'
UserParameter=SYN_SENT,netstat -ant|grep  -c 'SYN_SENT'
UserParameter=SYN_RECV,netstat -ant|grep  -c 'SYN_RECV'
UserParameter=FIN_WAIT1,netstat -ant|grep  -c 'FIN_WAIT1'
UserParameter=FIN_WAIT2,netstat -ant|grep  -c 'FIN_WAIT2'
UserParameter=TIME_WAIT,netstat -ant|grep  -c 'TIME_WAIT'
UserParameter=CLOSE,netstat -ant|grep  -c 'CLOSE'
UserParameter=CLOSE_WAIT,netstat -ant|grep  -c 'CLOSE_WAIT'
UserParameter=LAST_ACK,netstat -ant|grep  -c 'LAST_ACK'
UserParameter=LISTEN,netstat -ant|grep  -c 'LISTEN'
UserParameter=CLOSING,netstat -ant|grep  -c 'CLOSING'

2.重啟zabbix-agent

[root@web01 ~]# systemctl restart zabbix-agent.service 

3.測試監控項

使用zabbix-get命令測試

[root@m01 ~]# yum install zabbix-get.x86_64 -y
[root@m01 ~]# zabbix_get -s 10.0.1.7 -k ESTABLISHED
2
[root@m01 ~]# zabbix_get -s 10.0.1.7 -k LISTEN
12

3.導入模版文件

img

img

img

4.主機關聯模版文件

img

img

5.查看最新數據

img

6.查看圖形

img

第x章 自定義模版監控nginx狀態

比如監控Nginx的狀態, 怎麼做?

1.埠是否正常
2.stub_ status 7種狀態

  • 1.安裝nginx
    2.開啟stub_ status
    3.獲取每個狀態的指標
    4.將獲取到的狀態做成監控項
    5.在web界而創建模板->創建監控項(8次)-->創建觸發器(埠是否正常)

1.開啟監控頁面並訪問測試

[root@web01 ~]# cat /etc/nginx/conf.d/status.conf 
server {
   listen 80;
   server_name localhost;
   location /nginx_status {
       stub_status on;
       access_log off;
   }
}

[root@web01 ~]# curl -s 127.0.0.1/nginx_status/ #-s去除多餘的行數
Active connections: 1 
server accepts handled requests
 6 6 6 
Reading: 0 Writing: 1 Waiting: 0 

方法一:修改配置文件實現

1.安裝nginx
2.開啟stub_ status
3.獲取每個狀態的指標
Active
curl -s 127.0.0.1/nginx_ status |awk ' /^Active/ {print $NF}'
accepts
curl -s 127.0.0.1/nginx_ status|awk 'NR==3 {print $1}'
handled
curl -s 127.0.0.1/nginx_ status |awk ' NR==3 {print $2}'
request
curl -s 127.0.0.1/nginx_ status |awk ' NR==3 {print $3}'
4.將獲取到的狀態做成監控項
[ root@web01 zabbix_ _agentd.d]# cat nginx. conf
UserParameter=nginx.active,curl -s 127.0.0.1/nginx_ status |awk '/^Active/ {print $NF}'
UserParameter=nginx.accepts,curl -s 127.0.0.1/nginx_ status |awk 'NR==3 {print $1}'
UserParameter=nginx.handled,curl -s 127.0.0.1/nginx_status |awk 'NR==3{print $2}'
UserParameter=nginx.request,curl -s 127.0.0.1/nginx_ status| awk
'NR==3{print $3}'
5.重啟
systemctl restart zabbix-agent
6.在web界而創建模板->創建監控項(8次)-->創建觸發器(埠是否正常)

方法二:腳本實現

2.準備nginx監控狀態腳本

[root@web01 /etc/zabbix/zabbix_agentd.d]# cat nginx_monitor.sh 
#!/bin/bash
NGINX_COMMAND=$1
CACHEFILE="/tmp/nginx_status.txt"
CMD="/usr/bin/curl http://127.0.0.1/nginx_status/"
if [ ! -f $CACHEFILE  ];then
   $CMD >$CACHEFILE 2>/dev/null
fi
# Check and run the script
TIMEFLM=`stat -c %Y $CACHEFILE`
TIMENOW=`date +%s`

if [ `expr $TIMENOW - $TIMEFLM` -gt 60 ]; then
    rm -f $CACHEFILE
fi
if [ ! -f $CACHEFILE  ];then
   $CMD >$CACHEFILE 2>/dev/null
fi

nginx_active(){
         grep 'Active' $CACHEFILE| awk '{print $NF}'
         exit 0;
}
nginx_reading(){
         grep 'Reading' $CACHEFILE| awk '{print $2}'
         exit 0;
}
nginx_writing(){
         grep 'Writing' $CACHEFILE | awk '{print $4}'
         exit 0;
}
nginx_waiting(){
         grep 'Waiting' $CACHEFILE| awk '{print $6}'
         exit 0;
}
nginx_accepts(){
         awk NR==3 $CACHEFILE| awk '{print $1}' 
         exit 0;
}
nginx_handled(){
         awk NR==3 $CACHEFILE| awk '{print $2}' 
         exit 0;
}
nginx_requests(){
         awk NR==3 $CACHEFILE| awk '{print $3}'
         exit 0;
}

case $NGINX_COMMAND in
    active)
        nginx_active;
        ;;
    reading)
        nginx_reading;
        ;;
    writing)
        nginx_writing;
        ;;
    waiting)
        nginx_waiting;
        ;;
    accepts)
        nginx_accepts;
        ;;
    handled)
        nginx_handled;
        ;;
    requests)
        nginx_requests;
        ;;
    *)
echo 'Invalid credentials';
exit 2;
esac

3.編寫zabbix監控配置文件

[root@web01 ~]# cat /etc/zabbix/zabbix_agentd.d/nginx_status.conf
UserParameter=nginx_status[*],/bin/bash /etc/zabbix/zabbix_agentd.d/nginx_monitor.sh $1

[root@web01 ~]# systemctl restart zabbix-agent.service

4.使用zabbix_get取值

[root@m01 ~]# zabbix_get -s 10.0.1.7 -k nginx_status[accepts]
7

5.導入模版

img

6.鏈接模版

img

7.查看數據

img

補充:擴展一臺nginx怎麼監控

  • 1.狀態打開
  • 2.拷貝conf文件
  • 3.選則模板

第x章 自定義模版監控php狀態

1.開啟監控頁面

[root@web01 ~]# tail -1 /etc/php-fpm.d/www.conf    
pm.status_path = /php_status

[root@web01 ~]# cat /etc/nginx/conf.d/status.conf    
server {
   listen 80;
   server_name localhost;
   location /nginx_status {
       stub_status on;
       access_log off;
   }

   location /php_status {
       fastcgi_pass 127.0.0.1:9000;
       fastcgi_index index.php;
       fastcgi_param SCRIPT_FILENAME html$fastcgi_script_name;
       include fastcgi_params;
   }
}

[root@web01 ~]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web01 ~]# systemctl restart nginx.service php-fpm.service

2.訪問測試

[root@web01 ~]# curl 127.0.0.1/php_status
pool:                 www
process manager:      dynamic
start time:           08/Aug/2019:22:31:27 +0800
start since:          37
accepted conn:        1
listen queue:         0
max listen queue:     0
listen queue len:     128
idle processes:       4
active processes:     1
total processes:      5
max active processes: 1
max children reached: 0
slow requests:        0

3.準備訪問腳本

[root@web01 ~]# cat /etc/zabbix/zabbix_agentd.d/fpm.sh 
#!/bin/bash
##################################
# Zabbix monitoring script
#
# php-fpm:
#  - anything available via FPM status page
#
##################################
# Contact:
#  [email protected]
##################################
# ChangeLog:
#  20100922     VV      initial creation
##################################

# Zabbix requested parameter
ZBX_REQ_DATA="$1"
ZBX_REQ_DATA_URL="$2"

# Nginx defaults
NGINX_STATUS_DEFAULT_URL="http://localhost/fpm/status"
WGET_BIN="/usr/bin/wget"

#
# Error handling:
#  - need to be displayable in Zabbix (avoid NOT_SUPPORTED)
#  - items need to be of type "float" (allow negative + float)
#
ERROR_NO_ACCESS_FILE="-0.91"
ERROR_NO_ACCESS="-0.92"
ERROR_WRONG_PARAM="-0.93"
ERROR_DATA="-0.94" # either can not connect /   bad host / bad port

# Handle host and port if non-default
if [ ! -z "$ZBX_REQ_DATA_URL" ]; then
  URL="$ZBX_REQ_DATA_URL"
else
  URL="$NGINX_STATUS_DEFAULT_URL"
fi

# save the nginx stats in a variable for future parsing
NGINX_STATS=$($WGET_BIN -q $URL -O - 2>/dev/null)

# error during retrieve
if [ $? -ne 0 -o -z "$NGINX_STATS" ]; then
  echo $ERROR_DATA
  exit 1
fi

# 
# Extract data from nginx stats
#
#RESULT=$(echo "$NGINX_STATS" | awk 'print $0;match($0, "^'"$ZBX_REQ_DATA"':[[:space:]]+(.*)", a) { print a[1] }')
#RESULT=$(echo "$NGINX_STATS" | grep "$ZBX_REQ_DATA" | awk -F : '{print $2}')
RESULT=$(echo "$NGINX_STATS" | awk -F : "{if(\$1==\"$ZBX_REQ_DATA\") print \$2}")
if [ $? -ne 0 -o -z "$RESULT" ]; then
    echo $ERROR_WRONG_PARAM
    exit 1
fi

echo $RESULT

exit 0

[root@web01 ~]# bash /etc/zabbix/zabbix_agentd.d/fpm.sh "total processes" http://127.0.0.1/php_status
5

4.準備zabbix配置文件

[root@web01 ~]# cat /etc/zabbix/zabbix_agentd.d/fpm.conf    
UserParameter=php-fpm[*],/etc/zabbix/zabbix_agentd.d/fpm.sh "$1" "$2"
[root@web01 ~]# systemctl restart zabbix-agent.service

4.使用zabbix_get取值

[root@m01 ~]# zabbix_get -s 10.0.1.7 -k php-fpm["total processes",http://127.0.0.1/php_status]
5

5.導入模版

導入之後需要修改一下模版里的巨集配置

img

第x章 WEB監控

需求,監控頁面狀態碼

img

img

img

第x章 故障記錄

故障1

故障現象:
提示zabbix-server is not running

img

報錯日誌:

 34983:20190807:202215.171 database is down: reconnecting in 10 seconds
 34983:20190807:202225.172 [Z3001] connection to database 'zabbix' failed: [1045] Access denied for user 'zabbix'@'localhost' (using password: NO)

故障原因:
zabbix-server的配置文件里配有配置資料庫密碼
故障解決:
添加正確的資料庫賬號密碼信息

[root@m01 ~]# grep "^DB" /etc/zabbix/zabbix_server.conf     
DBHost=localhost
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix

故障2

故障現象:微信報警失敗
報錯日誌:

[root@m01 ~]# tail -f /var/log/zabbix/zabbix_server.log 
Problem name: TIME_WAIT過多
Host: web01
Severity: Average

Original problem ID: 51
'": Traceback (most recent call last):
  File "/usr/lib/zabbix/alertscripts/weixin.py", line 7, in <module>
    import requests
ImportError: No module named requests

問題原因:
缺少模塊 requests

問題解決:
安裝缺失的依賴包

[root@m01 ~]# yum install python-pip
[root@m01 ~]# pip install --upgrade pip
[root@m01 ~]# pip install requests

故障3

故障現象:
在server端使用zabbix_get命令測試鍵值命令時提示警告

[root@m01 ~]# zabbix_get -s 10.0.1.7 -k ESTABLISHED  
(Not all processes could be identified, non-owned process info
 will not be shown, you would have to be root to see it all.)
2

問題原因:
zabbix_agent是以普通用戶zabbix運行的,而普通用戶執行netstat -antp時會有警告,網上查找發現只要不是用p參數就可以以普通用戶運行
解決方案:
監控腳本里的命令修改為netstat -ant

知識點小結

1.zabbix組件
2.安裝zabbix-server

  • 修改源
  • 修改時區
  • 修改中文亂碼
  • 啟動服務端伺服器的agent
    3.添加監控主機
  • serverIP要寫對
  • selinux和防火牆
  • 修改為配置文件要重啟
    4.關聯zabbix自帶的linux監控模板
    5.自定義監控項
  • 你想要啥
  • shell命令如何取值
  • 寫自定義監控項配置文件
  • 修改完配置要重啟
  • web頁面操作
    6.自定義觸發器
    7.自定義圖形
    8.優化自定義監控項
    9.使用自定義模板替代重覆操作
  • 導出/導入
    10.郵件報警
  • 填寫的信息不能錯,不能瞎寫
  • 密碼寫的是QQ郵箱的授權碼,不是QQ密碼
  • 發送動作要打開,預設是停止的
    11.微信報警
  • 註冊企業號
  • 各種ID
  • 通訊錄邀請好友
  • 關註公眾號
  • 修改weixin腳本
  • web頁面操作
  • 發送到個人/群組

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 通過文件的inode號刪除文件 先用ls -i 找出要刪除文件的inode 號 ls -i |grep xxxxxx|awk '{print $2}'|xargs -i rm -f {} xxxxxx為文件的 inode 號通過文件大小刪除文件刪除當前目錄以及所有子目錄下的文件大小為零的文件find... ...
  • CentOS 7 離線環境安裝nginx時報錯:./configure: error: C compiler cc is not found,查看objs/autoconf.err文件中的報錯信息,對錯下包 ...
  • 此處承接前面未深入分析的頁面釋放部分,主要詳細分析伙伴管理演算法中頁面釋放的實現。頁面釋放的函數入口是__free_page(),其實則是一個巨集定義。 具體實現: 而__free_pages()的實現: 其中put_page_testzero()是對page結構的_count引用計數做原子減及測試,用 ...
  • 請看代碼,當你在centos下要把圖片轉為Base64的時候 明明你在本地或windows伺服器是正常的,可是在linux下就會拋出如下異常: 看了報錯信息知道 linux沒有 libgdiplus 解決方案: 其原因是沒有安裝mlocate這個包 安裝一下包:#yum -y install mlo ...
  • linux清理緩存的命令 查看緩存的命令 free -m 清理緩存的命令 echo 1 > /proc/sys/vm/drop_caches echo 2 > /proc/sys/vm/drop_caches echo 3 > /proc/sys/vm/drop_caches echo 0 是不釋放 ...
  • ctrl + s 的作用是暫停屏幕輸出 ctrl + q 恢復屏幕輸出即可 恢復之後會出現在暫停期間輸入的字元 ...
  • 查看shell cat /etc/shells 查看系統支持的shell echo $SHELL 查看目前正在使用的shell 快捷鍵 Ctrl+a 跳到行首 Ctrl+e 跳到行尾 Ctrl+u 刪除游標至行首的內容 Ctrl+k 刪除游標至行尾的內容 Ctrl+ c 拼接文件內容 tac 鏈接文 ...
  • 三極體共有3種工作狀態:截止狀態、放大狀態和飽和狀態。用於不同目的三極體其工作狀態是不同的。 三極體3種工作狀態電流特征 表1-7所示是三極體3種工作狀態定義和電流特征。 表1-7 三極體3種工作狀態定義和電流特征 三極體截止工作狀態 用來放大信號的三極體不應工作在截止狀態。倘若輸入信號部分地進入了 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...