學習zabbix(八)

一,Zabbix架構

zabbix 是一個基於 WEB 界面的提供分佈式系統監視以及網絡監視功能的企業級的開源解決方案。zabbix 能監視各類網絡參數,保證服務器系統的安全運營;並提供靈活的通知機制以讓系統管理員快速定位/解決存在的各類問題。javascript

Zabbix 的運行架構以下圖所示:php

QQ截圖20170423123759.png-456.8kB

1.1 組件

zabbix 由如下幾個組件部分構成:css

1) Zabbix Server:html

負責接收 agent 發送的報告信息的核心組件,全部配置,統計數據及操做數據均由其組織進行;前端

2) Database Storage:java

專用於存儲全部配置信息,以及由 zabbix 收集的數據;node

3) Web interface:mysql

zabbix 的 GUI 接口,一般與 Server 運行在同一臺主機上;linux

4) Proxy:ios

可選組件,經常使用於分佈監控環境中,代理 Server 收集部分被監控端的監控數據
並統一發往 Server 端;

5) Agent:

部署在被監控主機上,負責收集本地數據併發往 Server 端或 Proxy 端;

注:zabbix node 也是 zabbix server 的一種 。

1.2 進程

默認狀況下zabbix包含5個程序: zabbix_agentd、 zabbix_get、 zabbix_proxy、 zabbix_sender、zabbix_server,另一個 zabbix_java_gateway 是可選,這個須要另外安裝。

下面來分別介紹下他們各自的做用:

 zabbix_agentd

客戶端守護進程,此進程收集客戶端數據,例如 cpu 負載、內存、硬盤使用狀況等。

 zabbix_get

zabbix 工具,單獨使用的命令,一般在 server 或者proxy端執行獲取遠程客戶端信息的命令。 一般用戶排錯。 例如在server端獲取不到客戶端的內存數據, 咱們可使用zabbix_get獲取客戶端的內容的方式來作故障排查。

 zabbix_sender

zabbix 工具,用於發送數據給 server 或者proxy,一般用於耗時比較長的檢查。不少檢查很是耗時間,致使 zabbix 超時。因而咱們在腳本執行完畢以後,使用 sender 主動提交數據。

 zabbix_server

zabbix 服務端守護進程。zabbix_agentd、zabbix_get、zabbix_sender、zabbix_proxy、zabbix_java_gateway 的數據最終都是提交到 server
備註:固然不是數據都是主動提交給 zabbix_server,也有的是 server 主動去取數據。

 zabbix_proxy

zabbix 代理守護進程。功能相似server,惟一不一樣的是它只是一箇中轉站,它須要把收集到的數據提交/被提交到 server 裏。

 zabbix_java_gateway

zabbix2.0 以後引入的一個功能。顧名思義:Java 網關,相似 agentd,可是隻用於 Java方面。須要特別注意的是,它只能主動去獲取數據,而不能被動獲取數據。 它的數據最終會給到server或者proxy。

1.3 zabbix監控環境中相關術語

  • 主機(host) :

要監控的網絡設備,可由 IP 或 DNS 名稱指定;

  • 主機組(host group):

主機的邏輯容器,能夠包含主機和模板,但同一個組織內的主機和模板不能互相連接;主機組一般在給用戶或用戶組指派監控權限時使用;

 監控項(item) :

一個特定監控指標的相關的數據;這些數據來自於被監控對象;item是 zabbix 進行數據收集的核心,相對某個監控對象,每一個 item 都由"key"標識;

 觸發器(trigger) :

一個表達式,用於評估某監控對象的特定 item 內接收到的數據是否在合理範圍內,也就是閾值;接收的數據量大於閾值時,觸發器狀態將從"OK"轉變爲"Problem",當數據再次恢復到合理範圍,又轉變爲"OK";

 事件(event) :

觸發一個值得關注的事情,好比觸發器狀態轉變,新的 agent 或從新上
線的 agent 的自動註冊等;

 動做(action) :

指對於特定事件事先定義的處理方法,如發送通知,什麼時候執行操做;

 報警媒介類型(media) :

發送通知的手段或者通道,如 Email、Jabber 或者 SMS 等;

 模板 (template) :

用於快速定義被監控主機的預設條目集合, 一般包含了 item、 trigger、graph、 screen、 application 以及 low-level discovery rule;模板能夠直接連接至某個主機;

 前端(frontend) :

Zabbix 的 web 接口

二,ZabbixServer的安裝

2.1 搭建自定義yum倉庫並安裝支持包

QQ截圖20171129235049.png-27.8kB

[root@localhost rpm]# pwd
/root/rpm
[root@localhost rpm]# ls
fontconfig-2.8.0-5.el6.x86_64.rpm        libX11-common-1.6.4-3.el6.noarch.rpm
fontconfig-devel-2.8.0-5.el6.x86_64.rpm  libX11-devel-1.6.4-3.el6.x86_64.rpm
freetype-2.3.11-17.el6.x86_64.rpm        libXau-devel-1.0.6-4.el6.x86_64.rpm
freetype-devel-2.3.11-17.el6.x86_64.rpm  libxcb-1.12-4.el6.x86_64.rpm
gd-devel-2.0.35-11.el6.x86_64.rpm        libxcb-devel-1.12-4.el6.x86_64.rpm
libICE-1.0.6-1.el6.x86_64.rpm            libXext-1.3.3-1.el6.x86_64.rpm
libSM-1.2.1-2.el6.x86_64.rpm             libXpm-devel-3.5.10-2.el6.x86_64.rpm
libvpx-1.3.0-5.el6_5.x86_64.rpm          libXt-1.1.4-6.1.el6.x86_64.rpm
libvpx-devel-1.3.0-5.el6_5.x86_64.rpm    repodata
libX11-1.6.4-3.el6.x86_64.rpm            xorg-x11-proto-devel-7.7-14.el6.noarch.rpm
[root@localhost rpm]# cat /etc/yum.repos.d/CentOS-Media.repo 
[c6-media]
name=CentOS-$releasever - Media
baseurl=file:///media/CentOS/
        file:///media/cdrom/
        file:///media/cdrecorder/
gpgcheck=1
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

[rpm]
name=rpm
baseurl=file:///root/rpm/
gpgcheck=0
enabled=1

[root@localhost yum.repos.d]# yum -y install pcre pcre-devel zlib-devel libaio libaio-devel libxml2 libxml2-devel bzip2-devel openssl openssl-devel net-snmp-devel net-snmp curl-devel gd gcc gcc-c++ make libjpeg-devel libpng-devel libcurl-devel perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker mysql-devel net-snmp-utils

#若是下一步出現問題,請註釋掉yum配置文件裏的本地光盤源
[root@localhost rpm]# yum -y install libvpx-devel gd-devel

2.2 編譯安裝LNMP環境

2.2.1 安裝nginx

[root@localhost ~]# useradd -s /sbin/nologin -M www
[root@localhost ~]# tar xf nginx-1.10.2.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/nginx-1.10.2/
[root@localhost nginx-1.10.2]# ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_stub_status_module --with-http_ssl_module && make && make install
[root@localhost nginx-1.10.2]# ln -s /usr/local/nginx/sbin/* /usr/local/sbin/

#建立nginx配置文件模版
[root@localhost nginx-1.10.2]# cd /usr/local/nginx/conf/
[root@localhost conf]# egrep -v "^$|#" nginx.conf.default > nginx.conf

#將nginx配置文件改爲以下內容
[root@localhost conf]# vim nginx.conf
[root@localhost conf]# cat nginx.conf
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       80;
        server_name  localhost;
    location / {
        root   html;
        index  index.php index.html index.htm;
    }
    location = /nginx-status {
                stub_status on;
                access_log off;
        }
    location ~ \.php$ {
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}
[root@localhost conf]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

2.2.2 安裝mysql

[root@localhost ~]# tar xf mysql-5.5.32-linux2.6-x86_64.tar.gz -C /usr/local/
[root@localhost ~]# cd /usr/local/
[root@localhost local]# mv mysql-5.5.32-linux2.6-x86_64 mysql
[root@localhost local]# cd mysql/
[root@localhost mysql]# /bin/cp support-files/my-small.cnf /etc/my.cnf 
[root@localhost mysql]# useradd -s /sbin/nologin -M mysql
[root@localhost mysql]# chown -R mysql.mysql data
[root@localhost mysql]# /usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql
Installing MySQL system tables...
OK
Filling help tables...
OK
...如下省略若干...

[root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysqld
[root@localhost mysql]# chmod +x /etc/init.d/mysqld 
[root@localhost mysql]# /etc/init.d/mysqld start
Starting MySQL.. SUCCESS! 
[root@localhost mysql]# netstat -antup | grep 3306
tcp        0      0 0.0.0.0:3306                0.0.0.0:*                   LISTEN      3990/mysqld

2.2.3 安裝libmcrypt

[root@localhost ~]# tar xf libmcrypt-2.5.8.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/libmcrypt-2.5.8/
[root@localhost libmcrypt-2.5.8]# ./configure && make && make install

2.2.4 安裝GD

[root@localhost ~]# tar xf GD-2.18.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/GD-2.18/
[root@localhost GD-2.18]# perl Makefile.PL
[root@localhost GD-2.18]# make && make install

2.2.5 安裝PHP

[root@localhost ~]# tar xf php-5.6.30.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/php-5.6.30/
[root@localhost php-5.6.30]# ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --with-bz2 --with-curl --enable-sockets --disable-ipv6 --with-gd --with-jpeg-dir=/usr/local --with-png-dir=/usr/local --with-freetype-dir=/usr/local --enable-gd-native-ttf --with-iconv-dir=/usr/local --enable-mbstring --enable-calendar --with-gettext --with-libxml-dir=/usr/local --with-zlib --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --with-mysql=mysqlnd --enable-dom --enable-xml --enable-fpm --with-libdir=lib64 --enable-bcmath
[root@localhost php-5.6.30]# make && make install

#建立php配置文件
[root@localhost php-5.6.30]# cp php.ini-development /usr/local/php/etc/php.ini

#修改php配置文件php.ini
[root@localhost php-5.6.30]# cat -n /usr/local/php/etc/php.ini | sed -n '372p;382p;393p;660p;702p;820p;936p'
   372  max_execution_time = 300
   382  max_input_time = 300
   393  memory_limit = 256M
   660  post_max_size = 32M
   702  always_populate_raw_post_data = -1
   820  upload_max_filesize = 16M
   936  date.timezone =Asia/Shanghai

#建立php-fpm配置文件
[root@localhost php-5.6.30]# cd /usr/local/php/etc/
[root@localhost etc]# cp php-fpm.conf.default php-fpm.conf

#修改php-fpm.conf配置文件
[root@localhost etc]# cat -n php-fpm.conf | sed -n '149,150p'
   149  user = www
   150  group = www

2.3 安裝zabbix server端

2.3.1 編譯安裝zabbix server

[root@localhost ~]# useradd zabbix -s /sbin/nologin -M
[root@localhost ~]# tar xf zabbix-3.2.4.tar.gz -C /usr/src/
[root@localhost ~]# cd /usr/src/zabbix-3.2.4/
[root@localhost zabbix-3.2.4]# ./configure --prefix=/usr/local/zabbix --with-mysql --with-net-snmp --with-libcurl --enable-server --enable-agent --enable-proxy --with-libxml2
[root@localhost zabbix-3.2.4]# make && make install

#因爲zabbix啓動腳本路徑默認指向的是/usr/local/sbin路徑,所以,須要提早簡歷軟鏈接:
[root@localhost zabbix-3.2.4]# ln -s /usr/local/zabbix/sbin/* /usr/local/sbin/
[root@localhost zabbix-3.2.4]# ln -s /usr/local/zabbix/bin/* /usr/local/bin/

2.3.2 配置zabbix的mysql環境

Zabbix server 和mysql安裝到一臺服務器上,首先須要手動建立zabbix數據庫,操做以下:

[root@localhost ~]# which mysqladmin
/usr/bin/mysqladmin
[root@localhost ~]# mysqladmin -uroot password '123123'
[root@localhost ~]# mysql -uroot -p123123 -e 'create database zabbix character set utf8;'
[root@localhost ~]# mysql -uroot -p123123 -e "grant all privileges on zabbix.* to zabbix@'localhost' identified by '123123';"
[root@localhost ~]# mysql -uroot -p123123 -e 'flush privileges;'

#以下數據的導入順序不能夠錯
[root@localhost ~]# mysql -uzabbix -p123123 zabbix < /usr/src/zabbix-3.2.4/database/mysql/schema.sql 
[root@localhost ~]# mysql -uzabbix -p123123 zabbix < /usr/src/zabbix-3.2.4/database/mysql/images.sql 
[root@localhost ~]# mysql -uzabbix -p123123 zabbix < /usr/src/zabbix-3.2.4/database/mysql/data.sql 

2.4 安裝Zabbix web GUI

  • Zabbix web是php代碼編寫的,所以須要有php環境,前面已經安裝好了lnmp,所以能夠直接使用。
  • 默認的nginx安裝的根目錄爲/usr/local/nginx/html,所以,只須要Zabbix web的代碼放到此目錄便可。
  • Zabbix web的代碼在Zabbix源碼包中的frontends/php目錄下,將這個php目錄拷貝到/usr/local/nginx/html/目錄下並更名zabbix便可完成Zabbix web端的安裝。
  • 在瀏覽器輸入http://IP/zabbix,而後會檢查zabbix web運行環境是否知足,並提供鏈接數據庫的相關信息便可,最後將鏈接數據庫相關信息都存入文件zabbix/conf/zabbix.conf.php中,這樣就能夠登陸zabbix的web平臺了。
  • 默認的zabbix平臺登陸用戶名爲Admin,密碼爲zabbix。

2.4.1 複製zabbix web目錄到nginx web根目錄下

[root@localhost ~]# cp -rp /usr/src/zabbix-3.2.4/frontends/php /usr/local/nginx/html/zabbix
[root@localhost ~]# cd /usr/local/nginx/html/
[root@localhost html]# ls -l
total 12
-rw-r--r--.  1 root root  537 Dec  8 14:15 50x.html
-rw-r--r--.  1 root root  612 Dec  8 14:15 index.html
drwxr-xr-x. 13 1000 1000 4096 Feb 27  2017 zabbix
[root@localhost html]# chown -R www.www zabbix
[root@localhost html]# ll -d zabbix/
drwxr-xr-x. 13 www www 4096 Feb 27  2017 zabbix/

2.4.2 啓動nginx服務及php-fpm

[root@localhost html]# /usr/local/nginx/sbin/nginx 
[root@localhost html]# netstat -antup | grep nginx
tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      8439/nginx   
[root@localhost local]# /usr/local/php/sbin/php-fpm 
[root@localhost local]# netstat -antup | grep php-fpm
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      8522/php-fpm

2.4.3 登陸web根據提示生成zabbix.conf.php配置文件

#起初並無zabbix.conf.php配置文件,咱們能夠選擇自動生成配置文件
[root@localhost ~]# cd /usr/local/nginx/html/zabbix/conf
[root@localhost conf]# ls
maintenance.inc.php  zabbix.conf.php.example

在瀏覽器裏輸入http://IP/zabbix,配置zabbix數據庫環境,以下圖所示:

1.png-41.3kB

2.png-37.2kB

3.png-25.2kB

4.png-19.5kB

5.png-27.6kB

6.png-20kB

執行如上圖所示的步驟生成zabbix.conf.php配置文件

[root@localhost conf]# pwd
/usr/local/nginx/html/zabbix/conf
[root@localhost conf]# ls
maintenance.inc.php  zabbix.conf.php  zabbix.conf.php.example
[root@localhost conf]# cat zabbix.conf.php      #裏面記錄的信息就是咱們剛剛的操做
<?php
// Zabbix GUI configuration file.
global $DB;
 $DB['TYPE'] = 'MYSQL';
$DB['SERVER'] = 'localhost';
$DB['PORT'] = '0';
$DB['DATABASE'] = 'zabbix';
$DB['USER'] = 'zabbix';
$DB['PASSWORD'] = '123123';

// Schema name. Used for IBM DB2 and PostgreSQL.
$DB['SCHEMA'] = '';
 $ZBX_SERVER = 'localhost';
$ZBX_SERVER_PORT = '10051';
$ZBX_SERVER_NAME = 'zabbixserver';
 $IMAGE_FORMAT_DEFAULT = IMAGE_FORMAT_PNG;

提示:
除了經過web界面的方式生成zabbix.conf.php文件外,咱們也能夠利用zabbix.conf.php.example的模版文件直接修改爲咱們須要的配置文件。

2.4.4 登陸zabbix web

7.png-9.3kB

1.png-71.3kB

2.4.5 設置zabbix中文模式

1.png-50kB

2.png-30.1kB

3.png-47.6kB

三,zabbix server的配置

3.1 zabbix_server.conf配置

經過源碼安裝方式將zabbix安裝到/usr/local/zabbix下面,zabbix server的配置文件爲/usr/local/zabbix/etc/zabbix_server.conf,須要修改的內容爲以下:

#須要修改的內容爲以下:
[root@localhost ~]# cd /usr/local/zabbix/etc/
[root@localhost etc]# cat -n zabbix_server.conf | sed -n '12p;38p;87p;103p;111p;118p;136p;165p;181p;297p;447p'
    12  # ListenPort=10051
    38  LogFile=/tmp/zabbix_server.log
    87  DBName=zabbix
   103  DBUser=zabbix
   111  # DBPassword=
   118  # DBSocket=/tmp/mysql.sock
   136  # StartPollers=5
   165  # StartTrappers=5
   181  # StartDiscoverers=1
   297  # ListenIP=0.0.0.0
   447  # AlertScriptsPath=${datadir}/zabbix/alertscripts

#將zabbix_server.conf文件內容修改爲以下所示:
[root@localhost etc]# cat -n zabbix_server.conf | sed -n '12p;38p;87p;103p;111p;118p;136p;165p;181p;297p;447p'
    12  ListenPort=10051    #zabbix server監聽端口
    38  LogFile=/tmp/zabbix_server.log  #zabbix server日誌路徑
    87  DBName=zabbix   #zabbix server鏈接MySQL數據庫的數據庫名
   103  DBUser=zabbix   #zabbix server鏈接MySQL數據庫的用戶名
   111  DBPassword=123123   #zabbix server鏈接MySQL數據庫的密碼
   118  DBSocket=/tmp/mysql.sock    #MySQL的實例文件位置
   136  StartPollers=5  #用於設置zabbix server服務啓動時啓動Pollers(主動收集數據進程)的數量,數量越多,則服務端吞吐能力越強,同時對系統資源消耗越大
   165  StartTrappers=10    #用於設置zabbix server服務啓動時啓動Trappers(負責處理Agentd推送過來的數據的進程)的數量。Agentd爲主動模式時,zabbix server須要設置這個值大一些。
   181  StartDiscoverers=10 #用於設置zabbix server服務啓動時啓動Discoverers進程的數量,若是zabbix監控報Discoverers進程忙時,須要提升該值。
   297  ListenIP=0.0.0.0    #zabbix server啓動的監聽端口對哪些ip開放,Agentd爲主動模式時,這個值建議設置爲0.0.0.0
   447  AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts  #zabbix server運行腳本存放目錄,一些供zabbix server使用的腳本,均可以放在這裏。

3.2 添加相關服務和端口到系統配置文件

編輯/etc/services文件,在最後添加如下代碼:

[root@localhost ~]# tail -4 /etc/services 
zabbix-agent    10050/tcp       # Zabbix Agent
zabbix-agent    10050/udp       # Zabbix Agent
zabbix-trapper  10051/tcp       # Zabbix Trapper
zabbix-trapper  10051/udp       # Zabbix Trapper

其中,10051是zabbix server的監聽端口,10050是zabbix agent的監聽端口。

3.3 添加管理維護腳本

從zabbix源碼包misc/init.d/fedora/cora/目錄中找到zabbix_server和zabbix_agentd,而後複製到/etc/init.d目錄下,因爲咱們的zabbix_agnetd採用rpm的安裝方式,會自動添加啓動腳本,因此在此處,咱們不進行zabbix_agentd的啓動腳本的複製。

[root@localhost ~]# cp /usr/src/zabbix-3.2.4/misc/init.d/fedora/core/zabbix_server /etc/init.d/zabbix_server
[root@localhost ~]# cd /etc/init.d/
[root@localhost init.d]# chmod +x /etc/init.d/zabbix_server 
[root@localhost init.d]# chkconfig zabbix_server on

3.4 啓動zabbix_server端進程

[root@localhost ~]# /etc/init.d/zabbix_server start
Starting zabbix_server:                                    [ OK ]
[root@localhost ~]# netstat -antup | grep zabbix_server
tcp        0      0 0.0.0.0:10051               0.0.0.0:*                   LISTEN      9319/zabbix_server

四,zabbix_agent的安裝與配置

zabbix agent端的安裝建議採用rpm包方式安裝,可從http://repo.zabbix.com/zabbix/3.2/下載zabbix的agent端rpm包,版本與zabbix server端保持一致,安裝以下:

[root@localhost chen]# wget http://repo.zabbix.com/zabbix/3.2/rhel/6/x86_64/zabbix-agent-3.2.4-1.el6.x86_64.rpm
[root@localhost ~]# rpm -ivh zabbix-agent-3.2.4-1.el6.x86_64.rpm

安裝完成後,zabbix agent端已經安裝完成了,zabbix agent端的配置目錄位於/etc/zabbix下,可在此目錄進行配置文件的修改。

特別提示:

  • zabbix server的源碼包自己就包含了zabbix server端和zabbix agent端,所以,zabbix服務器端無需再安裝zabbix agent的rpm包。
  • 然而zabbix agent的rpm包是爲了方便在服務器上進行快速安裝而設計的快捷安裝包。
  • 所以爲了統一,監控端和被監控端的zabbix agent咱們都用rpm的安裝方式

修改zabbix agent端的配置文件

#須要修改的內容以下所示:
[root@Zabbix_Server ~]# cd /etc/zabbix/
[root@localhost zabbix]# cat -n zabbix_agentd.conf | sed -n '13p;32p;95p;103p;120p;136p;147p;265p;284p'
    13  PidFile=/var/run/zabbix/zabbix_agentd.pid
    32  LogFile=/var/log/zabbix/zabbix_agentd.log
    95  Server=127.0.0.1
   103  # ListenPort=10050
   120  # StartAgents=3
   136  ServerActive=127.0.0.1
   147  Hostname=Zabbix server
   265  Include=/etc/zabbix/zabbix_agentd.d/*.conf
   284  # UnsafeUserParameters=0

#將內容修改成以下所示:
[root@localhost zabbix]# cat -n zabbix_agentd.conf | sed -n '13p;32p;95p;103p;120p;136p;147p;265p;284p'
    13  PidFile=/var/run/zabbix/zabbix_agentd.pid   #進程pid存放路徑
    32  LogFile=/var/log/zabbix/zabbix_agentd.log   #zabbix agent日誌存放路徑
    95  Server=127.0.0.1,192.168.0.220  #指定zabbix server端IP地址
   103  ListenPort=10050    #指定agentd的監聽端口
   120  StartAgents=3       #指定啓動agentd進程數量。設置0表示關閉
   136  ServerActive=192.168.0.220:10051    #啓用agnetd主動模式,啓動主動模式後,agentd將主動將收集到的數據發送到zabbix server端,Server Active後面指定的IP就是zabbix server端IP
   147  Hostname=192.168.0.220 #須要監控服務器的主機名或者IP地址,此選項的設置必定要和zabbix web端主機配置中對應的主機名一致。
   265  Include=/etc/zabbix/zabbix_agentd.d/    #相關配置均可以放到此目錄下,自動生效
   284  UnsafeUserParameters=1  #啓用agent端自定義item功能,設置此參數爲1後,就可使用UserParameter指令了。UserParameter用於自定義item

啓動zabbix_agent端進程

[root@localhost ~]# /etc/init.d/zabbix-agent start
Starting Zabbix agent:                                     [  OK  ]
[root@localhost ~]# netstat -antup | grep zabbix_agent
tcp        0      0 0.0.0.0:10050               0.0.0.0:*                   LISTEN      1322/zabbix_agentd  
tcp        0      0 :::10050                    :::*                        LISTEN      1322/zabbix_agentd  
[root@localhost init.d]# chkconfig zabbix-agent on

咱們在監控端和被監控端都進行如上所述的zabbix agent端的安裝。

五,測試zabbix server監控

如何知道zabbix server監控已經生效呢,可經過zabbix server上的zabbix_get命令來完成,在zabbix server上執行以下命令便可進行測試:

#利用以下命令進行測試
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.221 -p 10050 -k "system.uptime"

-s 是指定zabbix agent端的IP地址
-p 是指定zabbix agent端的監聽端口
-k 是監控項,即item
若是有輸出結果,表面zabbix server能夠從zabbix agent獲取數據,配置成功。

具體操做以下:

#在監控端zabbix_server端進行以下操做
[root@localhost init.d]# /usr/local/zabbix/bin/zabbix_get -s 192.168.0.221 -p 10050 -k "system.uptime"
26330       #有數據顯示就表明監控正常
[root@localhost init.d]# /usr/local/zabbix/bin/zabbix_get -s 192.168.0.220 -p 10050 -k "system.uptime"
55653       #有數據顯示就表明監控正常

六,Zabbix的web操做入門

6.1 Zabbix Web 操做概述

6.1.1 Zabbix首頁儀表提示面板

1.png-54.3kB

  • 經常使用的圖形:能夠根據本身喜愛,添加按主機按監控項添加快捷的查看連接
  • 經常使用的聚合圖形:能夠將多個監控圖形的曲線合併顯示
  • 經常使用的拓撲圖:集羣的架構圖
  • 主機狀態:被監控的主機的實時狀態
  • Web檢測:發一個http請求,看看web是否能正常訪問
  • 系統狀態:監控端zabbix server服務器的狀態
  • 最近20個問題:最後發生的20個告警信息
  • Zabbix狀態:zabbix server監控的詳細彙總信息

6.1.2 自定義首頁面板

1.png-58.6kB

調整後,以下所示:

2.png-95.3kB

6.1.3 追加經常使用的監控圖形

1.png-68kB

1.png-75.9kB

1.png-37.2kB

6.1.4 修改帳戶密碼

1.png-5.8kB

2.png-22.6kB

3.png-19.5kB

6.1.5 設置報警提示聲音

1.png-5.2kB

2.png-19.8kB

3.png-39.7kB

6.1.6 獲取最新的zabbix共享模版

1.png-10.1kB

2.png-96.9kB

6.2 自定義被監控的服務器

6.2.1 自定義一個主機組

1.png-45.1kB

1.png-126.3kB

QQ截圖20171213000758.png-59.2kB

特別提示
在生產環境時,主機組的名字必定要用英文,否則,當zabbix進行二次開發的時候,中文名稱都是亂碼。那感受很讓人想死...

6.2.2 自定義一個主機

1.png-12.7kB

2.png-39.6kB

2.png-76.5kB

3.png-32.5kB

4.png-14.8kB

特別提示
在生產環境中主機的名字必定要是英文,而且務必和真實主機的主機名一致,且必須歸類加入到主機組中。否則zabbix在進行二次開發的時候會很是麻煩(須要創建相似索引形式的東西去關聯真實服務器)

6.3 自定義一個監控項

6.3.1 進行監控項的後臺定義

如今假如咱們要定義一個獲取nginx鏈接數的監控項,那麼咱們先得去嘗試可以獲取這個值。在以前的nginx配置文件裏咱們已經加入了status模塊的獲取

1.png-40.4kB

(1)咱們登陸網頁獲取這個信息

2.png-34.4kB

(2)咱們嘗試經過命令獲取這個信息

[root@localhost zabbix_agentd.d]# curl -s "http://192.168.0.220:80/nginx-status" 
Active connections: 6 
server accepts handled requests
 301 301 8833 
Reading: 0 Writing: 1 Waiting: 5 
[root@localhost zabbix_agentd.d]# curl -s "http://192.168.0.220:80/nginx-status" | grep "Active"
Active connections: 6 
[root@localhost zabbix_agentd.d]# curl -s "http://192.168.0.220:80/nginx-status" | grep "Active" | awk '{print $NF}'
6

(3)在zabbix agent配置文件裏定義這個監控項

[root@localhost ~]# cd /etc/zabbix/ #進入zabbix agent目錄
[root@localhost zabbix]# ls
zabbix_agentd.conf  zabbix_agentd.d
[root@localhost zabbix]# vim zabbix_agentd.conf 
[root@localhost zabbix]# sed -n '257,270p' zabbix_agentd.conf 
### Option: Include
# You may include individual files or all files in a directory in the configuration file.
# Installing Zabbix will create include directory in /usr/local/etc, unless modified during the compile time.
#
# Mandatory: no
# Default:
# Include=

Include=/etc/zabbix/zabbix_agentd.d/        #咱們發現zabbix_agentd.d目錄已經默認被include進入了主配置文件。

# Include=/usr/local/etc/zabbix_agentd.userparams.conf
# Include=/usr/local/etc/zabbix_agentd.conf.d/
# Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf

因爲zabbix_agentd.conf配置文件默認導入了全部zabbix_agentd.d目錄下的內容,所以咱們能夠將監控項定義到zabbix_agentd.d目錄下。

1.png-66kB

(4)參考模版,本身定義監控項的獲取命令

[root@localhost zabbix_agentd.d]# pwd
/etc/zabbix/zabbix_agentd.d
[root@localhost zabbix_agentd.d]# vim nginx.conf
[root@localhost zabbix_agentd.d]# cat nginx.conf 
[root@localhost zabbix_agentd.d]# cat nginx.conf 
UserParameter=nginx.active,/usr/bin/curl -s "http://192.168.0.220:80/nginx-status" | grep "Active" | awk '{print $NF}'

(5)自定義監控項,等於改變了配置文件,天然須要重啓zabbix_agentd

[root@localhost ~]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [ OK ]
Starting Zabbix agent:                                     [ OK ]

(6)在zabbix server端測試獲取自定義的監控項信息

[root@localhost ~]# zabbix_get -s 192.168.0.220 -p 10050 -k "nginx.active"
6

至此zabbix自定義監控項的後臺定義所有完成

6.3.2 進行監控項的前臺定義

(1)點選一個被監控的主機

1.png-84.3kB

(2)進入監控項建立模版

1.png-92kB

(3)建立監控項

1.png-92.8kB

2.png-41.7kB

(4)建立完成的監控項

3.png-183kB

監控項建立完成之後,在zabbix server這個主機裏就出現這個新定義的監控項了。

6.4 自定義一個監控項的圖形

(1)點選一個被監控的主機

1.png-84.3kB

(2)進入圖形建立模版

1.png-77.5kB

1.png-41.7kB

(3)查看圖形繪圖

1.png-47.2kB

(4)關於圖形的各類顯示效果

1.png-26.6kB

正常圖形:

1.png-26.7kB

層積圖形

2.png-20.8kB

Pie圖形

3.png-14kB

爆發的圖形

4.png-10.3kB

6.5 自定義一個聚合圖形

(1)建立一個聚合圖形

1.png-27.7kB

2.png-15.8kB

(2)編輯聚合圖形

3.png-21.8kB

1.png-20.6kB

1.png-24.3kB

(3)選擇展現圖形

2.png-15.8kB

2.png-38.7kB

1.png-92.3kB

1.png-114.9kB

(4)將聚合圖形添加到zabbix web首頁面板

1.png-26.6kB

2.png-76.1kB

3.png-64.5kB

6.6 自定義一個拓撲圖形

(1)進入拓撲圖編輯界面

1.png-22.8kB

2.png-28kB

(2)添加一個新的拓撲圖形

1.png-23.9kB

1.png-94.9kB

(3)拓撲圖連接拓撲圖

1.png-94.9kB

2.png-84kB

3.png-55.7kB

1.png-42.1kB

(4)拓撲圖顯示時時的鏈接帶寬

1.png-35.4kB

2.png-170.8kB

3.png-37.2kB

4.png-68.9kB

5.png-84.2kB

上圖中的標籤內容以下:
{linux-node1.yunjisuan.com:net.if.out[eth0].last(0)}
linux-node1.yunjisuan.com爲定義的主機名
net.if.out[eth0]爲監控項的表達式
last(0)爲取監控項的最後一個值

6.png-41.5kB

本節做業:

(1)熟悉Zabbix各模塊操做,回家胡亂點點

(2)自學部署Smokeping網絡監控

(3)自學Piwik流量分析系統

#######################################################################################

一,Zabbix Web操做深刻

1.1 Zabbix Web下的主機和模版以及監控項的添加方式

(1)建立一個模版

咱們全部的功能幾乎都是在模版中定義的

1.png-27.4kB

2.png-31kB

咱們再點進新建立的模版查看

模版裏幾乎能夠設定咱們須要的全部功能

1.png-31.8kB

2.png-32.9kB

(2)在模版裏建立應用集

應用集的做用就是將衆多的監控項進行一個分類,方便咱們的管理

1.png-26.2kB

2.png-17.3kB

3.png-19.3kB

(3)在模版裏建立一個zabbix自帶的監控項

1.png-26.4kB

2.png-158.7kB

(4)監控項裏的鍵值咱們到底要如何寫?咱們須要學會照葫蘆畫瓢

咱們選擇一個系統模版Template OS Linux查看

1.png-6kB

2.png-23.7kB

3.png-44.9kB

4.png-80.5kB

(5)固然咱們也能夠自定義監控項的鍵值,可是並不推薦這樣。由於,都是本身寫太慢了。系統自帶了不少鍵值咱們要學會利用

自定義系統監控項的鍵值建立,請參考前一節的知識

1.2 Zabbix Web下觸發器與表達式的編寫方法

(1)avg

參數:秒或#num
支持類型:float,int
做用:返回一段時間的平均值

舉例:
avg(5):最後5秒的平均值
avg(#5):表示最近5次獲得值的平均值
avg3600,86400):表示一天前的一個小時的平均值
若是僅有一個參數,表示指定時間的平均值,從如今開始算起,若是有第二個參數,表示漂移,從第二個參數前開始算時間,#n表示最近n次的值

(2)last

參數:秒或#num
支持值類型:float,int,str,text,log
做用:最近的值,若是爲秒,則忽略,#num表示最近第N個值,請注意當前的#num和其餘一些函數的#num的意思是不一樣的。

last(0)等價於last#1)
last#3)表示最近第3個值(並非最近的三個值)
本函數也支持第二個參數time_shift,例如last0,86400)返回一天前的最近的值。
若是在history中同一秒中有多個值存在看,Zabbix不保證值的精確順序#num從Zabbix1.6.2起開始支持,timeshift從1.8.2起開始支持,能夠查詢avg()函數獲取它的使用方法

(3)max

參數:秒或#num
支持值類型:float,int
描述:返回指定時間間隔的最大值。時間間隔做爲第一個參數能夠是秒或收集值的數目(前綴爲#)。從Zabbix1.8.2開始,函數支持第二個可選參數time_shift,能夠查看avg()函數獲取它的使用方法。
例如:max(#3)=0 返回3次值若是都是0則觸發告警

(4)min

參數:秒或#num
支持值類型:float,int
描述:返回指定時間間隔的最小值。時間間隔做爲第一個參數能夠是秒或收集值的數目(前綴爲#)。從Zabbix1.8.2開始,函數支持第二個可選參數time_shift,能夠查看avg()函數獲取它的使用方法。

(5)nodata

參數:秒
支持值類型:any
描述:當返回值爲1表示指定的間隔(間隔不該小於30秒)沒有接收到數據,0表示獲取到了。
例:nodata(5m)=1 ===>5分鐘以內獲取不到數據就告警

(6)prev

參數:忽略
支持值類型:float,int,str,text,log
描述:返回以前的值,相似於last(#2)

(7)sum

參數:秒或#num
支持值類型:float,int
描述:返回指定時間間隔中收集到的值的總和,時間間隔做爲第一個參數支持秒或收集值的數目(以#開始).從Zabbix1.8.2開始,本函數支持time_shift做爲第二個參數。能夠查看avg函數獲取它的用法。

(8)change

參數:忽略
支持類型:float,int,str,text,log
做用:返回最近得到值與以前得到值的差值,對於字符串0表示相等,1表示不一樣
change(0)>n:忽略參數通常輸入0,表示最近獲得的值與上一個值的差值大於n

(9)diff

參數:忽略
支持值類型:float,init,str,text,log
做用:返回值爲1,表示最近的值與以前的值不一樣,0爲相同。
例如:diff(0)>0 ===>表示如今獲取的值若是和以前的不一樣就告警

例如:

QQ截圖20180118093853.png-90.8kB

QQ截圖20180118094336.png-32kB

1.3 Zabbix Web建立觸發器過程以及觸發器與監控項對應關係

(1)建立一個觸發器

咱們以前已經建立了一個檢測內存剩餘大小的監控項,如今咱們給這個監控項加一個觸發器。當內存小於20M時,觸發報警

QQ截圖20180118100424.png-34.2kB

QQ截圖20180118105951.png-38.2kB

QQ截圖20180118110016.png-27.7kB

QQ截圖20180118110105.png-12.6kB

(2)進行表達器測試

QQ截圖20180118110530.png-30.1kB

QQ截圖20180118111111.png-27.1kB

QQ截圖20180118111332.png-29kB

QQ截圖20180118111424.png-20.5kB

QQ截圖20180118111443.png-14.1kB

表達式測試成功後,咱們建立完畢便可

(3)在服務端進行監控項數據獲取測試

QQ截圖20180118112715.png-33.2kB

監控項表達式說明
{aaaa:vm.memory.size[available].last()}<20M
aaaa:模版名
vm.memory.size:zabbix監控端向被監控端發送的代號
.last()<20 :last()<===>last(0)<===>last(#1)

[root@localhost ~]# zabbix_get -s 192.168.0.220 -k "vm.memory.size"
1028517888              #獲取對應IP的所有內存總量
[root@localhost ~]# zabbix_get -s 192.168.0.220 -k "vm.memory.size[available]"
794337280           #獲取對應IP的剩餘內存總量

1.4 爲了讓同窗們體會深入,咱們再建立一個監控項同時建立它的觸發器

(1)快速建立一個Agent_ping監控項

QQ截圖20180118114234.png-41.6kB

QQ截圖20180118114253.png-12.9kB

(2)在監控端測試監控項的鍵值

[root@localhost ~]# zabbix_get -s 192.168.0.220 -k "agent.ping"
1
[root@localhost ~]# zabbix_get -s 192.168.0.221 -k "agent.ping"
1
[root@localhost ~]# zabbix_get -s 192.168.0.222 -k "agent.ping"
zabbix_get [11715]: Get value error: cannot connect to [[192.168.0.222]:10050]: [113] No route to host

咱們發現若是對方服務器IP能ping通,則返回值是1。反之不是1就有問題

(3)建立監控項的告警觸發器

QQ截圖20180118114723.png-9.9kB

QQ截圖20180118114745.png-20.7kB

QQ截圖20180118114910.png-13.4kB

QQ截圖20180118114916.png-13.1kB

QQ截圖20180118114935.png-9.5kB

QQ截圖20180118114943.png-9.9kB

到這裏就建立完畢了,請同窗們仔細體會這個過程。

二,Zabbix經常使用模版與觸發器功能詳解

(1){Template App Zabbix Agent:agent.version.diff(0)}>0

解釋:
若是當前獲取的agent客戶端的版本號大於前一次的不一樣,那麼觸發告警

(2){Template App Zabbix Agent:agent.ping.nodata(5m)}=1

解釋:
若是ping客戶端在5分鐘內都沒有數據,那麼觸發告警

(3){Template OS AIX:vm.memory.size[available].last(0)}<20M

解釋:
若是最後一次獲取的空閒內存大小得值小於20M,那麼觸發告警

(4){Template App SSH Service:net.tcp.service[ssh].max(#3)}=0

解釋:
若是ssh遠程鏈接連續獲取的3次值的最大值都是0,那麼觸發告警

(5){Template ICMP Ping:icmppingloss.min(5m)}>20

解釋:
若是連續5分鐘裏獲取的最小值都大於20,那麼觸發告警

(6){Template ICMP Ping:icmppingsec.avg(5m)}>0.15

解釋:
若是連續5分鐘內的平均值大於0.15,那麼觸發告警

三,Zabbix報警媒介類型設置和告警動做、頻率設置

3.1 QQ郵件告警平臺

3.1.1 安裝sendmail

[root@localhost ~]# wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz
[root@localhost ~]# yum -y install perl-Net-SSLeay perl-IO-Socket-SSL
[root@localhost ~]# tar xf sendEmail-v1.56.tar.gz -C /usr/local/
[root@localhost ~]# cd /usr/local/sendEmail-v1.56/
[root@localhost sendEmail-v1.56]# /bin/cp -ra sendEmail /usr/local/bin/
[root@localhost sendEmail-v1.56]# chmod +x /usr/local/bin/sendEmail 
[root@localhost sendEmail-v1.56]# which sendmail
/usr/sbin/sendmail

3.1.2 sendmail命令使用說明

命令/參數 內容 解釋說明
/usr/local/bin/sendEmail 命令主程序
-f from@163.com 發件人郵箱
-t to@163.com 收件人郵箱
-s smtp.163.com 發件人郵箱的smtp服務器
-u "我是郵件主題" 郵件的標題
-o message-content-type=html 郵件內容的格式,html表示它是html格式
-o message-charset=utf8 郵件內容編碼
-xu from@163.com 發件人郵箱的用戶名
-xp 123456 發件人郵箱密碼(受權碼)
-m "我是郵件內容" 郵件的具體內容

3.1.3 調整QQ郵箱設置

QQ截圖20180119225714.png-57kB

QQ截圖20180119230151.png-29.7kB

QQ截圖20180119225952.png-26.7kB

測試郵件發送

[root@localhost sendEmail-v1.56]# sendEmail -f 215379068@qq.com -t 215379068@qq.com -u "zabbix_server" -s smtp.qq.com -o message-content-type=html -o message-charset=utf8 -xu 215379068@qq.com -xp rtqnwthiqajdbihd -m "郵件發送成功"
Jan 19 18:09:10 localhost sendEmail[2403]: Email was sent successfully!

QQ截圖20180119231007.png-53.4kB

3.1.4 編寫QQ郵件平臺報警腳本

[root@localhost alertscripts]# pwd
/usr/local/zabbix/share/zabbix/alertscripts
[root@localhost alertscripts]# cat sendmail.sh 
#!/bin/bash
# author:Mr.chen


to=$1

subject=$2

body=$3

from=215379068@qq.com

smtp=smtp.qq.com

passwd=rtqnwthiqajdbihd

/usr/local/bin/sendEmail -f "$from" -t "$to" -s "$smtp" -u "$subject" -o message-content-type=html -o message-charset=utf8 -xu "$from" -xp "$passwd" -m "$body"
[root@localhost alertscripts]# chmod +x sendmail.sh 
[root@localhost alertscripts]# chown zabbix.zabbix sendmail.sh 

3.1.5 腳本測試

[root@localhost alertscripts]# sh sendmail.sh 215379068@qq.com "hello world" "新的一天"
Jan 19 18:20:32 localhost sendEmail[2478]: Email was sent successfully!

QQ截圖20180119232055.png-56.9kB

3.1.6 修改zabbix_server.conf配置文件

[root@localhost alertscripts]# cat -n /usr/local/zabbix/etc/zabbix_server.conf | grep "447"
   447  # AlertScriptsPath=${datadir}/zabbix/alertscripts

#將上述內容修改爲以下所示
[root@localhost alertscripts]# cat -n /usr/local/zabbix/etc/zabbix_server.conf | grep "447"
   447  AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts

#重啓zabbix_server服務
[root@localhost zabbix]# /etc/init.d/zabbix_server restart
Shutting down zabbix_server:                               [  OK  ]
Starting zabbix_server:                                    [  OK  ]

3.1.7 建立報警媒介

QQ截圖20180119234327.png-34.9kB

QQ截圖20180119234558.png-24.5kB

QQ截圖20180119234640.png-32.4kB

QQ截圖20180119234839.png-25.3kB

QQ截圖20180120223425.png-31.3kB

3.1.8 建立報警動做

QQ截圖20180119235155.png-26.2kB

QQ截圖20180120110138.png-26.4kB

QQ截圖20180120110308.png-31kB

QQ截圖20180120110353.png-50.6kB

步驟1-3也就是從1開始到3結束。一旦發生故障,就是執行sendmail.sh腳本發生報警郵件給zabbix用戶。
假如故障持續了1個小時,它也只發送3次,第1-3次(即前3次)郵箱發送給zabbix用戶,時間間隔爲0秒。
若是改爲1-0,0是表示不限制,無限發送。

QQ截圖20180120110812.png-34.9kB

QQ截圖20180120110850.png-14.6kB

3.1.9 QQ郵件報警測試

給自定義監控項nginx.avtive建立一個觸發器,以下

QQ截圖20180120230607.png-15.5kB

利用Web進行訪問,增長活動鏈接數,觸發報警

QQ截圖20180120224433.png-77.9kB

3.2 微信報警平臺

3.2.1 註冊微信報警平臺並綁定微信號

企業號註冊鏈接:https://qy.weixin.qq.com/cgi-bin/loginpage

QQ截圖20180121001001.png-45.7kB

QQ截圖20180121001247.png-36kB

QQ截圖20180121001751.png-19.2kB

3.2.2 編寫微信平臺報警腳本

編寫腳本前,咱們須要先記住3個關鍵的參數

(1)企業的CorpID

QQ截圖20180121005237.png-58.6kB

(2)企業的Secret

QQ截圖20180121005310.png-38kB

QQ截圖20180121005334.png-9kB

(3)部門ID號

QQ截圖20180121005557.png-47.2kB

而後咱們就能夠編寫微信告警腳本了,以下:

[root@Zabbix_Server alertscripts]# cat weixin.sh 
#!/bin/bash
# author:Mr.chen

CropID="########"           #這裏填寫咱們的應用的CropID

Secret="#######"            #這裏是應用的Secret

#下面的GURL和PURL地址無需改變,不用作任何變更
GURL="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$CropID&corpsecret=$Secret"

Gtoken=`/usr/bin/curl -s -G $GURL | awk -F\" '{print $10}'` PURL="https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=$Gtoken" function body() { local int AppID=1000002 #這裏是建立的應用ID local UserID=$1 #接收消息用戶,系統傳參 local PartyID=1 #接收消息的部門ID local Msg=`echo "$@" | cut -d" " -f3-` printf '{\n' printf '\t"touser": "'"$UserID"\"",\n" printf '\t"toparty": "'"$PartyID"\"",\n" printf '\t"msgtype": "text",\n' printf '\t"agentid": "'" $AppID "\"",\n" printf '\t"text": {\n' printf '\t\t"content": "'"$Msg"\""\n" printf '\t},\n' printf '\t"safe":"0"\n' printf '}\n' } /usr/bin/curl --data-ascii "$(body $1 $2 $3)" $PURL 

3.2.3 腳本測試

[root@Zabbix_Server alertscripts]# chmod +x weixin.sh 
[root@Zabbix_Server alertscripts]# chown zabbix.zabbix weixin.sh 
[root@Zabbix_Server alertscripts]# sh weixin.sh yinsendemogui "題目" "報警內容"
{"errcode":0,"errmsg":"ok","invaliduser":"#######"}

IMG_3575.PNG-62.5kB

IMG_3576.PNG-53.3kB

3.2.4 建立微信報警媒介類型

QQ截圖20180121011219.png-25.6kB

QQ截圖20180121011244.png-35.4kB

QQ截圖20180121011307.png-21.8kB

QQ截圖20180121011355.png-14.1kB

QQ截圖20180121011413.png-25.1kB

3.2.5 設定報警動做

QQ截圖20180121011641.png-17.9kB

QQ截圖20180121011900.png-25kB

3.2.6 微信平臺報警測試

QQ截圖20180121012248.png-65.4kB

IMG_3577.PNG-118.4kB

3.3 自定義自動報警的內容

(1)自定義內容樣例

若是不修改報警的內容格式,看起來太亂了。咱們能夠按照以下方式修改

#告警通知格式樣例
#題目
A故障:{TRIGGER.STATUS},服務器:{HOSTNAME1}發生:{TRIGGER.NAME}故障!
#內容
告警主機:&nbsp;{HOSTNAME1}<br/>
告警時間:&nbsp;{EVENT.DATE} {EVENT.TIME}<br/>
告警等級:&nbsp;{TRIGGER.SEVERITY}<br/>
告警信息:&nbsp;{TRIGGER.NAME}<br/>
告警項目:&nbsp;{TRIGGER.KEY1}<br/>
問題詳情:&nbsp;{ITEM.NAME}&nbsp{ITEM.VALUE}<br/>
當前狀態:&nbsp;{TRIGGER.STATUS}&nbsp{ITEM.VALUE1}<br/>
事件ID:&nbsp;{EVENT.ID}

QQ截圖20180121195205.png-40.7kB

(2)樣例測試

QQ截圖20180121195126.png-67.1kB

四,用戶參數User parameters

4.1 概述

有時候當咱們監控的項目在Zabbix預約義的key中沒有定義時,這時候咱們能夠經過編寫Zabbix的用戶參數的方法來監控咱們要求的項目item。形象一點說Zabbix代理端配置文件中的User parameters就至關於經過腳本獲取要監控的值,而後把相關的腳本或者命令寫入到配置文件中的User parameter中,而後Zabbix server讀取配置文件中的返回值經過處理前端的方式返回給用戶。

用戶參數的語法

UserParameter=<key>,<command>

其中,Userparameter爲關鍵字,key爲用戶自定義key名字能夠隨便起,

一個簡單的例子:

UserParameter=ping,echo 1

代理程序將會永遠的返回1,當咱們在服務器端添加item的key爲ping的時候。

稍微複雜的例子:

UserParameter=mysql.ping,/usr/local/mysql/bin/mysqladmin ping | grep -c alive

  • 當咱們執行mysqladmin -uroot ping命令的時候若是mysql存活要返回mysqld is alive,咱們經過grep -c來計算mysqld is alive的個數,若是mysql存活着,則個數爲1,若是不存活很明顯mysqld is alive的個數爲0,經過這種方法咱們能夠來判斷mysql的存活狀態。
  • 當咱們在服務器端添加item的key爲mysql.ping時候,對於Zabbix代理程序,若是mysql存活,則狀態將返回1,不然,狀態將返回0。

4.2 讓key接受參數

讓key也接受參數的方法使item添加時更具有了靈活性,例如系統預約義key:vm.memory.size[

相關語法:

UserParameter=key[*],command

#描述:

key:key的值在主機系統中必須是惟一的,其中*表明命令中接受的參數

command:客戶端系統中可執行的命令

#舉例:

UserParameter=ping[*],echo $1
ping[0]:此時0就是*,也就是傳入參數是0,$1也就是0,所以表達式將一直返回‘0’
ping[aaa]:此時aaa就是*,也就是傳入參數是aaa,$1也就是aaa,所以表達式將一直返回‘aaa’

4.3 讓咱們自定義一個能夠傳遞參數的監控項

咱們作一個能夠根據條件獲取內存數值大小的監控項mem_check
當咱們鍵值爲mem_check[free]時,獲取剩餘可用內存大小
當咱們鍵值爲mem_check[used]時,獲取實際佔用內存大小
當咱們鍵值爲mem_check時,獲取總內存大小

4.3.1 咱們先製做一個獲取數據的腳本

[root@Zabbix_Server ~]# mkdir -p /server/scripts
[root@Zabbix_Server ~]# cd /server/scripts/
[root@Zabbix_Server scripts]# cat mem_check 
#!/bin/bash
# author:Mr.chen

case $1 in
    free)
        echo "`free | awk 'NR==3{print $4}'`"
        ;;
    used)
        echo "`free | awk 'NR==3{print $3}'`"
        ;;
    *)
        echo "`free | awk 'NR==2{print $2}'`"
        ;;
esac

4.3.2 測試腳本

[root@Zabbix_Server scripts]# chmod +x mem_check 
[root@Zabbix_Server scripts]# chown zabbix.zabbix mem_check
[root@Zabbix_Server scripts]# sh mem_check 
1004412
[root@Zabbix_Server scripts]# sh mem_check free
782492
[root@Zabbix_Server scripts]# sh mem_check used
221912

4.3.3 後臺自定義一個監控項的鍵值

[root@Zabbix_Server ~]# cd /etc/zabbix/zabbix_agentd.d/
[root@Zabbix_Server zabbix_agentd.d]# cat mem_check.conf 
UserParameter=mem.check[*],/server/scripts/mem_check $1

4.3.4 測試自定義的鍵值

#重啓zabbix-agent客戶端
[root@Zabbix_Server zabbix_agentd.d]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [ OK ]
Starting Zabbix agent:                                     [ OK ]
[root@Zabbix_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "mem.check"
1004412
[root@Zabbix_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "mem.check[free]"
782676
[root@Zabbix_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "mem.check[used]"
221744

4.3.5 前臺自定義一個監控項及觸發器

過程略,此時我相信同窗們已經會了。請同窗們本身嘗試建立完整。

五,Agentd主動模式與被動模式

默認狀況下,zabbix server會直接去每一個agent上抓取數據,這對於agent來講,是被動模式,也是默認的一種獲取數據的方式,可是,當zabbix server監控主機數量過多的時候,由server端去抓取agent上的數據,zabbix server會出現嚴重的性能問題,主要表現以下:

  • [x] :Web操做很卡,容易出現502
  • [x] :圖層斷裂
  • [x] :開啓的進程(Pollar)太多,即便減小item數量,之後加入必定量的機器也會有問題

因此,下面主要往兩個優化方向考慮:

  • [x] :用Proxy或者Node模式作分佈式監控
  • [x] :調整Agentd爲主動模式

5.1 Agentd的配置調整

修改zabbix_agentd.conf配置文件,注意是打開以下參數:

ServerActive=192.168.0.220
Hostname=192.168.0.220
StartAgents=1

ServerActive是指定Agentd收集的數據往哪裏發送,Hostname是必需要和zabbix web端添加主機時的主機名對應起來,這樣zabbix server端接收到數據才能找到對應關係,這裏爲了兼容被動模式,沒有把StartAgents設爲0,若是一開始就是使用主動模式的話建議把StartAgents設爲0,關閉被動模式。

5.2 zabbix Server端配置調整

若是開啓了agent端的主動發送數據模式,須要在zabbix Server端修改以下兩個參數,保證性能。

StartPollers=10     #把這個zabbix Server主動收集數據進程減小一些。
StartTrappers=200   #把這個負責處理Agentd推送過來的數據的進程開大一些。

5.3 調整模版

  • 所以收集數據的模式發生了變化,所以須要把全部的監控項的類型由原來的「zabbix客戶端」改爲「zabbix客戶端(主動式)」。
  • 這樣,只須要簡單的幾步,就完成了主動模式的切換,調整以後服務器不卡了,圖層不裂了,進程也少了。

QQ截圖20180121221430.png-46.7kB

######################################################################################

一,Zabbix生產環境監測案例概述

1.1 項目規劃

  • [x] :主機分組
    • 交換機
    • Nginx
    • Tomcat
    • MySQL
    • Apache
    • PHP-fpm
    • redis(也有狀態頁,同窗們本身研究)
    • memcache(也有狀態頁,同窗們本身研究)
  • [x] :監控對象識別:
    • 使用SNMP監控交換
    • 使用IPMI監控服務器硬件
    • 使用Agent監控服務器
    • 使用JMX監控JAVA
    • 監控MySQL
    • 監控Web狀態
    • 監控Nginx狀態
    • 監控Apache狀態
    • 監控Tomcat狀態

1.2 SNMP監控流程

  1. 交換機上開啓snmp
  2. 在zabbix上添加監控(設置SNMP interfaces)
  3. 關聯監控模版

1.3 IPMI

建議使用自定義item監控服務器硬件,在本地執行ipmitool命令來獲取數據

能夠在本地執行ipmitool命令獲取數據(命令須要安裝)

1.4 JMX(使用Zabbix Java Gateway代理)

用來獲取java數據,本次的實戰內容

1.5 實戰監控Nginx,Apache,MySQL,PHP-fpm

今天的實戰內容,請同窗們注意總結過程

1.6 Zabbix的Web監測

今天的實戰內容,請同窗們注意總結過程

二,Zabbix監控MySQL數據庫操做實戰

咱們須要部署一個MySQL服務和一個zabbix-agentd客戶端

2.1 編寫監控腳本

在nginx服務器(192.168.0.221)上安裝一個MySQL
下面是監控mysql狀態的一個shell腳本,內容以下:

[root@nginx scripts]# pwd
/server/scripts
[root@nginx scripts]# cat check_mysql.sh 
#!/bin/bash
# author:Mr.chen

MySQL_USER="root"
MySQL_PWD="123123"
MySQL_HOST="127.0.0.1"
MySQL_PORT="3306"

MySQL_CONN="/usr/local/mysql/bin/mysqladmin -u${MySQL_USER} -h${MySQL_HOST} -P${MySQL_PORT} -p${MySQL_PWD}"

if [ $# -ne "1" ];then
    echo "arg error!"
fi

case $1 in
    Uptime)
        result=`${MySQL_CONN} status | cut -f2 -d":" | cut -f1 -d "T"`
        echo $result
        ;;
    Com_update)
        result=`${MySQL_CONN} extended-status | grep -w "Com_update" | cut -d"|" -f3`
        echo $result
        ;;
    Slow_querles)
        result=`${MySQL_CONN} status | cut -f5 -d":" | cut -f1 -d"O"`
        echo $result
        ;;
    Com_select)
        result=`${MySQL_CONN} extended-status | grep -w "Com_select" | cut -d "|" -f3`
        echo $result
        ;;
    Com_rollback)
        result=`${MySQL_CONN} extended-status | grep -w "Com_rollback" | cut -d"|" -f3`
        echo $result
        ;;
    Questions)
        result=`${MySQL_CONN} status | cut -f4 -d":" | cut -f1 -d"S"`
        echo $result
        ;;
    Com_insert)
        result=`${MySQL_CONN} extended-status | grep -w "Com_insert" | cut -d"|" -f3`
        echo $result
        ;;
    Com_delete)
        result=`${MySQL_CONN} extended-status | grep -w "Com_delete" | cut -d"|" -f3`
        echo $result
        ;;
    Com_commit)
        result=`${MySQL_CONN} extended-status | grep -w "Com_commit" | cut -d"|" -f3`
        echo $result
        ;;
    Bytes_sent)
        result=`${MySQL_CONN} extended-status | grep -w "Bytes_sent" | cut -d"|" -f3`
        echo $result
        ;;
    Bytes_received)
        result=`${MySQL_CONN} extended-status | grep -w "Bytes_received" | cut -d"|" -f3`
        echo $result
        ;;
    Com_begin)
        result=`${MySQL_CONN} extended-status | grep -w "Com_begin" | cut -d"|" -f3`
        echo $result
        ;;
    *)
        echo "Usage:$0(Uptime|Com_update|Slow_querles|Com_rollback|Questions|Com_insert|Com_delete|Com_commit|Bytes_sent|Bytes_received|Com_begin)"
        ;;
esac

2.2 在zabbix-agent端建立自定義鍵值配置文件

#建立mysql.status的鍵值
[root@nginx scripts]# chmod +x check_mysql.sh 
[root@nginx scripts]# chown zabbix.zabbix check_mysql.sh
[root@nginx zabbix]# cd /etc/zabbix/zabbix_agentd.d/
[root@nginx zabbix_agentd.d]# cat mysql_status.conf 
UserParameter=mysql.status[*],/server/scripts/check_mysql.sh $1

#刪除舊鍵值模版
[root@nginx zabbix_agentd.d]# rm -rf userparameter_mysql.conf 

#建立mysql.ping和mysql.version的鍵值
[root@nginx zabbix_agentd.d]# cat mysql_status.conf 
UserParameter=mysql.status[*],/server/scripts/check_mysql.sh $1
UserParameter=mysql.ping,/usr/local/mysql/bin/mysqladmin -uroot -p123123 ping | grep -c alive
UserParameter=mysql.version,/usr/local/bin/mysql -V

#重啓zabbix-agentd服務
[root@nginx zabbix_agentd.d]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [  OK  ]
Starting Zabbix agent:                                     [  OK  ]

2.3 在zabbix-server端測試鍵值

[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Uptime]"
2791
[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Com_commit]"
0
[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Bytes_sent]"
144628
[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.status[Bytes_received]"
3934
[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.ping"
1
[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.221 -p 10050 -k "mysql.version"
/usr/local/bin/mysql  Ver 14.14 Distrib 5.5.32, for linux2.6 (x86_64) using readline 5.1

2.4 在zabbix-server端Web前臺引入zabbix監控MySQL的模版

zabbix自帶監控MySQL的模版,咱們只須要將模版引入到主機便可
配置-->主機-->選擇主機-->模板,而後將MySQL模版鏈接到此主機便可

QQ截圖20180122210222.png-42.2kB

QQ截圖20180122210235.png-25.5kB

QQ截圖20180122210257.png-20.8kB

QQ截圖20180122210610.png-36.3kB

QQ截圖20180122210625.png-88kB

從圖中能夠發現模版裏的鍵值都是咱們以前已經定義好了的鍵值。

三,Zabbix監控Apache、Nginx操做實戰

3.1 實戰監控Apache

3.1.1 源碼編譯構建apache服務

#爲了不衝突,若系統中已經安裝httpd服務,務必刪除
[root@apache ~]# rpm -q httpd
package httpd is not installed
[root@apache ~]# /etc/init.d/iptables stop
[root@apache ~]# setenforce 0
setenforce: SELinux is disabled

#源碼構建apache
[root@apache httpd-2.2.17]# tar xf httpd-2.2.17.tar.gz -C /usr/src/
[root@apache httpd-2.2.17]# cd /usr/src/httpd-2.2.17/
[root@apache httpd-2.2.17]# ./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi && make && make install
[root@apache httpd-2.2.17]# cd /usr/local/httpd/
[root@apache httpd]# ls
bin  build  cgi-bin  conf  error  htdocs  icons  include  lib  logs  man  manual  modules
[root@apache httpd]# ln -s /usr/local/httpd/bin/* /usr/local/bin/
[root@apache httpd]# cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd
[root@apache httpd]# chmod +x /etc/init.d/httpd
[root@apache ~]# cd /usr/local/httpd/htdocs/
[root@apache htdocs]# echo "`hostname -I` I am apache" > index.html
[root@apache htdocs]# cat index.html 
192.168.0.222  I am apache
[root@apache conf]# awk '/#ServerName/{print NR,$0}' httpd.conf 
97 #ServerName www.example.com:80
[root@apache conf]# sed -i -e '97 s/#//;s/example/yunjisuan/' httpd.conf 
[root@apache conf]# sed -n '97p' httpd.conf 
ServerName www.yunjisuan.com:80
[root@apache conf]# /etc/init.d/httpd start
[root@apache conf]# netstat -antup | grep httpd
tcp        0      0 :::80                       :::*                        LISTEN      53288/httpd         
[root@apache conf]# echo "`hostname -I` www.yunjisuan.com" >> /etc/hosts
[root@apache conf]# tail -1 /etc/hosts
192.168.0.222  www.yunjisuan.com
[root@apache conf]# curl www.yunjisuan.com
192.168.0.222  I am apache

3.1.2 開啓apache狀態頁

要打開apache的ServerStatus頁面,須要在httpd.conf文件最下邊加入代碼段

ExtendedStatus On
<location /server-status>
SetHandler server-status
Order Deny,Allow
Deny from all
Allow from 127.0.0.1
</location>

最後,重啓動apache便可

3.1.3 下載apache zabbix模版並解壓

#從以下地址下載apache zabbix模版:
[root@apache ~]# wget https://github.com/lorf/zapache/archive/master.zip
#解壓zip格式壓縮文件
[root@apache ~]# unzip master
[root@apache ~]# ls -d zapache-master
zapache-master
[root@apache ~]# cd zapache-master/
[root@apache ~]# tree zapache-master/
zapache-master/
├── httpd-server-status.conf.sample
├── README.md
├── userparameter_zapache.conf.sample
├── zapache
├── zapache-template-active.xml
└── zapache-template.xml

0 directories, 6 files
  • 此模版文件中包含了監控apache的腳本文件,zabbix的apache模版文件,還有客戶端zabbix自定義傳key文件。
  • 首先將zapache放到須要監控的apache服務器上的/etc/zabbix/scripts目錄下,若是沒有scripts目錄,自行建立一個便可。而後執行受權:
[root@apache zapache-master]# chmod 755 /etc/zabbix/scripts/zapache
[root@apache scripts]# cd /etc/zabbix/scripts/
[root@apache scripts]# ./zapache 
zapache version: 1.5
usage:
  ./zapache [<url>] TotalAccesses                 - Check total accesses.
  ./zapache [<url>] TotalKBytes                   - Check total KBytes.
  ./zapache [<url>] CPULoad                       - Check CPU load.
  ./zapache [<url>] Uptime                        - Check uptime.
  ./zapache [<url>] ReqPerSec                     - Check requests per second.
  ./zapache [<url>] BytesPerSec                   - Check Bytes per second.
  ./zapache [<url>] BytesPerReq                   - Check Bytes per request.
  ./zapache [<url>] BusyWorkers                   - Check busy workers.
  ./zapache [<url>] IdleWorkers                   - Check idle workers.
  ./zapache [<url>] version                       - Version of this script.
  ./zapache [<url>] ping                          - Check if Apache is up.
  ./zapache [<url>] WaitingForConnection          - Check Waiting for Connection processess.
  ./zapache [<url>] StartingUp                    - Check Starting Up processess.
  ./zapache [<url>] ReadingRequest                - Check Reading Request processess.
  ./zapache [<url>] SendingReply                  - Check Sending Reply processess.
  ./zapache [<url>] KeepAlive                     - Check KeepAlive Processess.
  ./zapache [<url>] DNSLookup                     - Check DNSLookup Processess.
  ./zapache [<url>] ClosingConnection             - Check Closing Connection Processess.
  ./zapache [<url>] Logging                       - Check Logging Processess.
  ./zapache [<url>] GracefullyFinishing           - Check Gracefully Finishing Processess.
  ./zapache [<url>] IdleCleanupOfWorker           - Check Idle Cleanup of Worker Processess.
  ./zapache [<url>] OpenSlotWithNoCurrentProcess  - Check Open Slots with No Current Process.
  • 接着將userparameter_zapache.conf.sample文件放到/etc/zabbix/zabbix_agentd.d目錄下,並重命名爲userparameter_zapache.conf文件,而後修改鍵值命令的路徑。
  • 最後,重啓zabbix-agent服務
[root@apache zapache-master]# mv userparameter_zapache.conf.sample /etc/zabbix/zabbix_agentd.d/userparameter_zapache.conf
[root@apache zabbix_agentd.d]# tail -1 userparameter_zapache.conf 
UserParameter=zapache[*],/etc/zabbix/scripts/zapache \$1    #本行要修改
[root@apache zapache-master]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [  OK  ]
Starting Zabbix agent:                                     [  OK  ]

3.1.4 測試鍵值

#在zabbix-agent端查看腳本用法
[root@apache zabbix_agentd.d]# cd /etc/zabbix/scripts/
[root@apache scripts]# ./zapache 
zapache version: 1.5
usage:
  ./zapache [<url>] TotalAccesses                 - Check total accesses.
  ./zapache [<url>] TotalKBytes                   - Check total KBytes.
  ./zapache [<url>] CPULoad                       - Check CPU load.
  ./zapache [<url>] Uptime                        - Check uptime.
  ./zapache [<url>] ReqPerSec                     - Check requests per second.
  ./zapache [<url>] BytesPerSec                   - Check Bytes per second.
  ./zapache [<url>] BytesPerReq                   - Check Bytes per request.
  ./zapache [<url>] BusyWorkers                   - Check busy workers.
  ./zapache [<url>] IdleWorkers                   - Check idle workers.
  ./zapache [<url>] version                       - Version of this script.
  ./zapache [<url>] ping                          - Check if Apache is up.
  ./zapache [<url>] WaitingForConnection          - Check Waiting for Connection processess.
  ./zapache [<url>] StartingUp                    - Check Starting Up processess.
  ./zapache [<url>] ReadingRequest                - Check Reading Request processess.
  ./zapache [<url>] SendingReply                  - Check Sending Reply processess.
  ./zapache [<url>] KeepAlive                     - Check KeepAlive Processess.
  ./zapache [<url>] DNSLookup                     - Check DNSLookup Processess.
  ./zapache [<url>] ClosingConnection             - Check Closing Connection Processess.
  ./zapache [<url>] Logging                       - Check Logging Processess.
  ./zapache [<url>] GracefullyFinishing           - Check Gracefully Finishing Processess.
  ./zapache [<url>] IdleCleanupOfWorker           - Check Idle Cleanup of Worker Processess.
  ./zapache [<url>] OpenSlotWithNoCurrentProcess  - Check Open Slots with No Current Process.

咱們發現腳本須要傳遞兩個參數,即url和選項
而後咱們在zabbix-server端進行鍵值測試

[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.222 -p 10050 -k "zapache[127.0.0.1 TotalAccesses]"
9
[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.222 -p 10050 -k "zapache[www.yunjisuan.com version]"
1.5
[root@Zabbix_Server scripts]# zabbix_get -s 192.168.0.222 -p 10050 -k "zapache[www.yunjisuan.com ping]"
1

3.1.5 在zabbix-server的Web頁面上監控apache

(1)建立一個監控apache的主機

QQ截圖20180122233702.png-36.7kB

QQ截圖20180122233846.png-28.8kB

(2)導入帶有apache監控項的模版

zabbix默認並無監控apache的監控項模版。咱們須要將它導入到apache中。在以前解壓出來的目錄中,有待導入的web模版

[root@apache ~]# tree zapache-master/
zapache-master/
├── httpd-server-status.conf.sample
├── README.md
├── zapache-template-active.xml #Web模版
└── zapache-template.xml    #Web模版

0 directories, 4 files

咱們將這兩個.xml後綴的拷貝到windows上,而後從Web界面導入進去

QQ截圖20180122234457.png-17.2kB

QQ截圖20180122234649.png-32.8kB

導入之後Web端就有監控apache的監控項模版了

(3)將模版連接到apache主機

QQ截圖20180122234811.png-27.5kB

QQ截圖20180122234841.png-23.9kB

QQ截圖20180122235146.png-26.2kB

3.2 實戰監控nginx

3.2.1 開啓nginx狀態頁

#在nginx的配置文件中,添加status配置
location = /nginx-status {
    stub_status on;
    access_log  off;
    allow 127.0.0.1;
    allow 192.168.0.220;    #zabbix服務器地址通常是內網地址
    deny all;
}

3.2.2 訪問設置好的nginx-status連接

#在zabbix-server上經過以下方式獲取nginx狀態頁面信息:
root@Zabbix_Server ~]# curl 192.168.0.221/nginx-status
Active connections: 1 
server accepts handled requests
 634 634 618 
Reading: 0 Writing: 1 Waiting: 0 

nginx status詳細說明以下:
Active connections:對後端發起的活動鏈接數;
accepts:nginx總共處理了多少個鏈接;
handled:nginx成功建立了幾回握手;
requests:nginx總共處理了多少請求。
Reading:nginx讀取客戶端的header數;
Writing:nginx返回給客戶端的header數;
Waiting:nginx請求處理完成,正在等待下一請求指令的鏈接

3.2.3 編寫nginx狀態監控腳本

#下面是nginx狀態監控抓取腳本,內容以下:
[root@nginx scripts]# cat nginx_status.sh 
#!/bin/bash
# Set Variables

HOST="127.0.0.1"
PORT="80"

#Functions to return nginx stats

function active(){
    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | grep "Active" | awk '{print $NF}'
}

function reading(){

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | grep "Reading" | awk '{print $2}'
}

function writing(){

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | grep "Writing" | awk '{print $4}'
}

function accepts(){

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | awk 'NR==3' | awk '{print $1}'

}

function handled(){

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | awk 'NR==3' | awk '{print $2}'
}

function requests(){

    /usr/bin/curl "http://$HOST:$PORT/nginx-status" 2>/dev/null | awk 'NR==3' | awk '{print $3}'
}

function ping(){

    /sbin/pidof nginx | wc -l
}

# Run the requested function

$1

3.2.4 給腳本可執行權限而且受權

[root@nginx scripts]# chmod +x nginx_status.sh 
[root@nginx scripts]# chown zabbix.zabbix nginx_status.sh

3.2.5 在zabbix-agent端配置nginx鍵值配置文件

[root@nginx zabbix_agentd.d]# pwd
/etc/zabbix/zabbix_agentd.d
[root@nginx zabbix_agentd.d]# cat nginx.conf 
UserParameter=nginx.active,/usr/bin/curl -s "http://127.0.0.1:80/nginx-status" | grep "Active" | awk '{print $NF}'
UserParameter=nginx.status[*],/etc/zabbix/scripts/nginx_status.sh $1
#重啓agent客戶端
[root@nginx zabbix_agentd.d]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent:                                [  OK  ]
Starting Zabbix agent:                                     [  OK  ]

3.2.6 在zabbix-server端測試鍵值

[root@Zabbix_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[reading]" -p 10050
0
[root@Zabbix_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[active]" -p 10050
1
[root@Zabbix_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[reading]" -p 10050
0
[root@Zabbix_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[writing]" -p 10050
1
[root@Zabbix_Server ~]# zabbix_get -s 192.168.0.221 -k "nginx.status[ping]" -p 10050
1

3.2.7 接下來咱們須要在Web端導入nginx監控模版

QQ截圖20180126105441.png-26.7kB

QQ截圖20180126105511.png-49.3kB

QQ截圖20180126105523.png-34.5kB

QQ截圖20180126105544.png-29.5kB

3.2.8 異常調試

若是Zabbix圖形界面一直沒有獲取到數據,能夠經過在zabbix server上執行zabbix_get手動測試:
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.221 -p 10050 -k "nginx.status[active]"
若是獲取數據有問題,會給出相應提示,若是可以獲取到數據,那就沒問題了。

四,Zabbix監控Tomcat操做實戰

zabbix監控tomcat,須要zabbix_server開啓java poller,zabbix_java開啓javaGateway,端口10052,Tomcat JMX開啓12345端口,提供性能數據。

數據獲取流程爲:java poller<-->javaGateway:10052<-->Tomcat:12345

QQ截圖20180126111607.png-76.3kB

4.1 配置Tomcat JMX

#配置jmx,在須要監控的tomcat服務器上,編輯catalina.sh,加入以下配置
[root@Tomcat bin]# sed -n '249p' /usr/local/tomcat/bin/catalina.sh 
CATALINA_OPTS="-server -Xms256m -Xmx512m -XX:PermSize=64M -XX:MaxPermSize=128m -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=192.168.0.224 -Dcom.sun.management.jmxremote.port=12345"

這裏須要注意,必須增長-Djava.rmi.server.hostname選項,而且後面的IP就是tomcat服務器的IP

4.2 重啓Tomcat

[root@Tomcat bin]# /usr/local/tomcat/bin/shutdown.sh 
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/jdk
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
[root@Tomcat ~]# netstat -antup | grep java
[root@Tomcat bin]# /usr/local/tomcat/bin/startup.sh 
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/jdk
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
[root@Tomcat zabbix]# netstat -antup | grep java
tcp        0      0 :::54031                    :::*                        LISTEN      1521/java           
tcp        0      0 :::8080                     :::*                        LISTEN      1521/java           
tcp        0      0 :::53881                    :::*                        LISTEN      1521/java           
tcp        0      0 :::12345                    :::*                      LISTEN      1521/java          #新增端口 
tcp        0      0 ::ffff:127.0.0.1:8005       :::*                        LISTEN      1521/java           
tcp        0      0 :::8009                     :::*                        LISTEN      1521/java

4.3 編譯zabbix,加入java支持

在zabbix server服務器上,編譯安裝zabbix-server,須要加上--enable-java,以支持jmx監控,若是以前的zabbix server沒加此選項,那麼須要從新編譯安裝,編譯參數以下:

./configure --prefix=/usr/local/zabbix --with-mysql --with-net-snmp --with-libcurl --enable-server --enable-agent --enable-proxy --enable-java --with-libxml2

特別提示:
在啓用--enable-java編譯zabbix以前,zabbix server服務器上須要安裝JDK,並須要設置JAVA_HOME,以讓系統可以識別到jdk的路徑

4.3.1 在zabbix-server端安裝JDK

#解壓jdk
[root@Zabbix_Server ~]# tar xf jdk-8u60-linux-x64.tar.gz -C /usr/local/
[root@Zabbix_Server ~]# ln -s /usr/local/jdk1.8.0_60/ /usr/local/jdk
#配置java環境變量
[root@Zabbix_Server ~]# sed -i.ori '$a export JAVA_HOME=/usr/local/jdk\nexport PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH\nexport CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar' /etc/profile
[root@Zabbix_Server ~]# tail -3 /etc/profile
export JAVA_HOME=/usr/local/jdk export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
export CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
#讓環境變量馬上生效
[root@Zabbix_Server ~]# source /etc/profile
#檢查java環境變量狀況
[root@Zabbix_Server ~]# which java
/usr/local/jdk/bin/java
[root@Zabbix_Server ~]# java -version
java version "1.8.0_60"
Java(TM) SE Runtime Environment (build 1.8.0_60-b27)
Java HotSpot(TM) 64-Bit Server VM (build 25.60-b23, mixed mode)

4.3.2 從新編譯zabbix-server服務器端

#從新編譯zabbix-server服務器端以前
[root@Zabbix_Server ~]# ll /usr/local/zabbix/sbin/
total 8604
-rwxr-xr-x 1 root root 1165774 Jan 20 15:16 zabbix_agentd
-rwxr-xr-x 1 root root 3672055 Jan 20 15:16 zabbix_proxy
-rwxr-xr-x 1 root root 3966037 Jan 20 15:16 zabbix_server

#開始從新編譯zabbix-server服務器端
[root@Zabbix_Server ~]# 
[root@Zabbix_Server ~]# /etc/init.d/zabbix_server stop
Shutting down zabbix_server:                               [  OK  ]
[root@Zabbix_Server ~]# cd /usr/src/zabbix-3.2.4/
[root@Zabbix_Server zabbix-3.2.4]# ./configure --prefix=/usr/local/zabbix --with-mysql --with-net-snmp --with-libcurl --enable-server --enable-agent --enable-proxy --enable-java --with-libxml2
[root@Zabbix_Server zabbix-3.2.4]# make && make install

#從新編譯zabbix-server服務器端以後
[root@Zabbix_Server zabbix-3.2.4]# cd /usr/local/zabbix/sbin/
[root@Zabbix_Server sbin]# ll
total 8608
-rwxr-xr-x 1 root root 1165774 Jan 25 22:22 zabbix_agentd
drwxr-xr-x 4 root root    4096 Jan 25 22:22 zabbix_java     #多了一個目錄
-rwxr-xr-x 1 root root 3672055 Jan 25 22:22 zabbix_proxy
-rwxr-xr-x 1 root root 3966037 Jan 25 22:22 zabbix_server
[root@Zabbix_Server sbin]# cd zabbix_java/
[root@Zabbix_Server zabbix_java]# ll
total 20
drwxr-xr-x 2 root root 4096 Jan 25 22:22 bin
drwxr-xr-x 2 root root 4096 Jan 25 22:22 lib
-rw-r--r-- 1 root root  791 Jan 25 22:22 settings.sh    #java gateway配置腳本
-rwxr-xr-x 1 root root  545 Jan 25 22:22 shutdown.sh    #中止java gateway服務
-rwxr-xr-x 1 root root 2025 Jan 25 22:22 startup.sh     #啓動java gateway服務

提示:
java gateway服務的配置腳本settings.sh不須要修改任何配置。

4.3.3 啓動java Gateway服務

[root@Zabbix_Server zabbix_java]# /usr/local/zabbix/sbin/zabbix_java/startup.sh 
[root@Zabbix_Server zabbix_java]# netstat -antup | grep 10052
tcp        0      0 :::10052                    :::*                        LISTEN      13126/java

4.4 修改zabbix server 配置

默認的狀況下,zabbix server未啓用javaPollers,須要修改zabbix_server.conf的以下配置

[root@Zabbix_Server zabbix]# cd /usr/local/zabbix/etc/

#修改如下配置文件的內容
[root@Zabbix_Server etc]# cat -n zabbix_server.conf | sed -n '215p;223p;231p'
   215  # JavaGateway=
   223  # JavaGatewayPort=10052
   231  # StartJavaPollers=0

#將上述配置文件內容修改爲以下
[root@Zabbix_Server etc]# cat -n zabbix_server.conf | sed -n '215p;223p;231p'
   215  JavaGateway=127.0.0.1   #JavaGateway的地址
   223  JavaGatewayPort=10052
   231  StartJavaPollers=5

#查看已經打開的java poller進程
[root@Zabbix_Server ~]# ps -ef | grep "java poller" | grep -v grep
zabbix    13233  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #1 [got 0 values in 0.000001 sec, idle 5 sec]
zabbix    13234  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #2 [got 0 values in 0.000015 sec, idle 5 sec]
zabbix    13235  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #3 [got 0 values in 0.000001 sec, idle 5 sec]
zabbix    13236  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #4 [got 0 values in 0.000001 sec, idle 5 sec]
zabbix    13237  13172  0 Jan25 ?        00:00:00 /usr/local/sbin/zabbix_server: java poller #5 [got 0 values in 0.000001 sec, idle 5 sec]

4.5 重啓zabbix_server服務

[root@Zabbix_Server ~]# /etc/init.d/zabbix_server start
Starting zabbix_server:                                    [ OK ]
[root@Zabbix_Server ~]# netstat -antup | grep 10051
tcp        0      0 0.0.0.0:10051               0.0.0.0:*                   LISTEN      13172/zabbix_server 
tcp        0      0 192.168.0.220:10051         192.168.0.221:56752         TIME_WAIT   -                   
tcp        0      0 192.168.0.220:10051         192.168.0.221:56754         TIME_WAIT   -                   
tcp        0      0 192.168.0.220:10051         192.168.0.221:56751         TIME_WAIT   -                   
tcp        0      0 192.168.0.220:10051         192.168.0.220:47162         TIME_WAIT   -

4.6 Zabbix圖形界面配置

4.6.1 建立一個主機利用JMX接口監控tomcat被監控端

1.png-49.1kB

2.png-44.5kB

4.6.2 導入zabbix監控tomcat的模版

由於Zabbix自帶的Tomcat模版有兼容性問題,並很差用,所以,咱們導入本身製做的監控項模版

1.png-28.6kB

2.png-53.5kB

3.png-29.9kB

QQ截圖20180128192111.png-42.8kB

最後咱們關聯模版便可。

QQ截圖20180128211056.png-60.3kB

五,Zabbix監控PHP-FPM操做實戰

php-fpm和nginx同樣內建了一個狀態頁,對於想了解php-fpm的狀態以及監控php-fpm很是有幫助

5.1 啓用php-fpm狀態功能

修改php-fpm配置文件,確保以下配置是打開狀態:
pm.status_path = /status,具體操做以下

#在Zabbix-server端操做以下
[root@Zabbix_Server etc]# pwd
/usr/local/php/etc
[root@Zabbix_Server etc]# ls
pear.conf  php-fpm.conf  php-fpm.conf.default  php.ini
[root@Zabbix_Server etc]# sed -n '360p' php-fpm.conf
;pm.status_path = /status
[root@Zabbix_Server etc]# vim php-fpm.conf +360
[root@Zabbix_Server etc]# sed -n '360p' php-fpm.conf
pm.status_path = /status

#重啓php-fpm服務
[root@Zabbix_Server ~]# netstat -antup | grep php-fpm
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      1145/php-fpm
[root@Zabbix_Server ~]# pkill php-fpm
[root@Zabbix_Server ~]# netstat -antup | grep 9000
[root@Zabbix_Server ~]# /usr/local/php/sbin/php-fpm 
[root@Zabbix_Server ~]# netstat -antup | grep php-fpm
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      18918/php-fpm

5.2 nginx配置php-fpm狀態頁面

在nginx配置文件nginx.conf裏配置php狀態頁,操做以下

[root@Zabbix_Server ~]# cd /usr/local/nginx/
[root@Zabbix_Server nginx]# ls
client_body_temp  conf  fastcgi_temp  html  logs  proxy_temp  sbin  scgi_temp  uwsgi_temp
#配置php-fpm狀態頁面
[root@Zabbix_Server nginx]# vim conf/nginx.conf
[root@Zabbix_Server nginx]# cat conf/nginx.conf
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.php index.html index.htm;
        }
        location = /nginx-status {
            stub_status on;
            access_log off;
        }
        location = /status {         #添加此location
            include fastcgi_params;
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
        }
        location ~ \.php$ {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include fastcgi_params;
        }
    }
}
#重啓動nginx服務
[root@Zabbix_Server nginx]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@Zabbix_Server nginx]# /usr/local/nginx/sbin/nginx -s reload

5.3 狀態頁瀏覽器訪問測試

php-fpm狀態頁比較個性化的一個地方是它能夠帶參數,能夠帶的參數有json、xml、html,使用zabbix或者nagios監控能夠考慮使用xml或者默認方式。

QQ截圖20180130230603.png-19kB

#具體含義說明以下
[root@Zabbix_Server nginx]# curl 127.0.0.1/status
pool:                 www           #fpm進程池名稱,大多數爲www
process manager:      dynamic       #進程管理方式(static,dynamic or nodemand.dynamic)
start time:           26/Jan/2018:02:56:58 -0500    #啓動日期
start since:          2972          #運行時長
accepted conn:        517           #當前FPM進程池接受的請求數
listen queue:         0             #請求等待隊列,若是值不是0,那麼要增長FPM的進程數
max listen queue:     4             #請求等待隊列最高的數量
listen queue len:     128           #socket等待隊列長度
idle processes:       2             #空閒進程數量
active processes:     1             #活躍進程數量
total processes:      3             #總進程數量
max active processes: 3             #最大的活躍進程數量(FPM啓動開始算)
max children reached: 0             #達到最大子進程的次數,若是值不爲0,那麼須要調高最大進程數
slow requests:        0             #當啓用了php-fpm的slow-log功能時,若是出現php-fpm慢請求這個計數器會增長,通常不當的MySQL查詢會觸發這個值

其餘狀態參數顯示形式的數據(json,xml,html)

#以xml的格式輸出PHP-fpm狀態頁
[root@Zabbix_Server nginx]# curl 127.0.0.1/status?xml
<?xml version="1.0" ?>
<status>
<pool>www</pool>
<process-manager>dynamic</process-manager>
<start-time>1516953418</start-time>
<start-since>3731</start-since>
<accepted-conn>647</accepted-conn>
<listen-queue>0</listen-queue>
<max-listen-queue>4</max-listen-queue>
<listen-queue-len>128</listen-queue-len>
<idle-processes>2</idle-processes>
<active-processes>1</active-processes>
<total-processes>3</total-processes>
<max-active-processes>3</max-active-processes>
<max-children-reached>0</max-children-reached>
<slow-requests>0</slow-requests>

#以json的格式輸出PHP-fpm的狀態頁
</status>[root@Zabbix_Server nginx]# curl 127.0.0.1/status?json
{"pool":"www","process manager":"dynamic","start time":1516953418,"start since":3736,"accepted conn":648,"listen queue":0,"max listen queue":4,"listen queue len":128,"idle processes":2,"active processes":1,"total processes":3,"max active processes":3,"max children reached":0,"slow requests":0}[root@Zabbix_Server nginx]# 

#以html的格式輸出PHP-fpm的狀態頁
[root@Zabbix_Server nginx]# curl 127.0.0.1/status?html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head><title>PHP-FPM Status Page</title></head>
<body>
<table>
<tr><th>pool</th><td>www</td></tr>
<tr><th>process manager</th><td>dynamic</td></tr>
<tr><th>start time</th><td>26/Jan/2018:02:56:58 -0500</td></tr>
<tr><th>start since</th><td>3748</td></tr>
<tr><th>accepted conn</th><td>650</td></tr>
<tr><th>listen queue</th><td>0</td></tr>
<tr><th>max listen queue</th><td>4</td></tr>
<tr><th>listen queue len</th><td>128</td></tr>
<tr><th>idle processes</th><td>2</td></tr>
<tr><th>active processes</th><td>1</td></tr>
<tr><th>total processes</th><td>3</td></tr>
<tr><th>max active processes</th><td>3</td></tr>
<tr><th>max children reached</th><td>0</td></tr>
<tr><th>slow requests</th><td>0</td></tr>
</table>
</body></html>

5.4 在Zabbix agent端修改配置

在建立Zabbix的agent端鍵值配置文件的時候,咱們能夠考慮利用PHP-fpm狀態頁的不一樣輸出格式來抓取數據。例如咱們利用xml格式獲取數據,操做以下:

#查看xml格式PHP-fpm狀態頁數據
root@Zabbix_Server nginx]# curl 127.0.0.1/status?xml
<?xml version="1.0" ?>
<status>
<pool>www</pool>
<process-manager>dynamic</process-manager>
<start-time>1516953418</start-time>
<start-since>3731</start-since>
<accepted-conn>647</accepted-conn>
<listen-queue>0</listen-queue>
<max-listen-queue>4</max-listen-queue>
<listen-queue-len>128</listen-queue-len>
<idle-processes>2</idle-processes>
<active-processes>1</active-processes>
<total-processes>3</total-processes>
<max-active-processes>3</max-active-processes>
<max-children-reached>0</max-children-reached>
<slow-requests>0</slow-requests>

#建立zabbix監控的agent端鍵值配置文件
[root@Zabbix_Server ~]# cd /etc/zabbix/zabbix_agentd.d/
[root@Zabbix_Server zabbix_agentd.d]# cat userparameter_php-fpm.conf 
UserParameter=php-fpm.status[*],/usr/bin/curl -s "http://127.0.0.1/status?xml" | grep "<$1>" | awk -F "[>|<]" '{print $$3}' #這裏須要注意在腳本里若是寫成$3的話,腳本會認識是一個變量,所以咱們須要用$$3 #重啓動agent客戶端 [root@Zabbix_Server ~]# /etc/init.d/zabbix-agent restart Shutting down Zabbix agent: [ OK ] Starting Zabbix agent: [ OK ]

5.5 進行鍵值配置文件測試

[root@Zabbix_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "php-fpm.status[process-manager]"
dynamic
[root@Zabbix_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "php-fpm.status[start-since]"
5634
[root@Zabbix_Server zabbix_agentd.d]# zabbix_get -s 192.168.0.220 -p 10050 -k "php-fpm.status[active-processes]"
1

5.6 Zabbix圖形界面導入咱們的監控模版

QQ截圖20180130235651.png-51.5kB

QQ截圖20180130235713.png-28kB

六,Zabbix的Web監測功能

Zabbix的Web監測功能,沒有任何依賴,不須要agent端,所有依賴於Server的主動監測

利用Web監測,監測Server端的nginx首頁

QQ截圖20180131001529.png-53.9kB

QQ截圖20180131001542.png-34.3kB

QQ截圖20180131002003.png-47.8kB

QQ截圖20180131002105.png-22kB

QQ截圖20180131002314.png-23.3kB

QQ截圖20180131002455.png-25.5kB

QQ截圖20180131002555.png-32kB

到這裏Web監測咱們就建立好了,最後再看一下監控結果

QQ截圖20180131002646.png-22.9kB

七,思考與做業

請同窗們在Zabbix監控MySQL的模版示例的基礎上,自定義一個監控數據庫主從複製的監控項

IP地址 主機名 用途
192.168.0.220 Zabbix_Server服務器 Zabbix監控端/主MySQL
192.168.0.221 Nginx服務器 Nginx服務器/從MySQL
相關文章
相關標籤/搜索