您好,登錄后才能下訂單哦!
Zabbix 3.0 分布式監控 [九]
2016年10月11日
zabbix
筆者QQ:381493251
Zabbix Proxy
是一個類似于代理的服務,可以代替Zabbix-server
獲取 zabbix-agent
信息。其中數據
存到本地(Proxy有自己的數據庫)然后在發送給Server,這樣可以保證數據不丟失
Zabbix-server ----->Zabbix-Proxy ----->Zabbix-Server
地址:https://www.zabbix.com/documentation/3.0/manual/distributed_monitoring/proxies
常用于多機房情況或者監控主機特別多,幾千臺左右。這時候使用Zabbix Proxy 可以減輕服務器server
的壓力,還可以減輕Zabbix的維護。
最常用的特點是適用于多機房
、網絡不穩定
的時候,因為如果直接由Zabbix-server發送信息可能agent沒有收到,但是直接使用Zabbix-Proxy
就不會遇到這個問題。
Zabbix官方說明(分布式監控)
Proxy 有如下功能
地址: https://www.zabbix.com/documentation/3.0/manual/distributed_monitoring
NO - 中文解釋
1.沒有Web界面
2.本身不做任何告警通知(告警通知都是Server做)
小結:
Zabbix Proxy
可以有多個,用來代理Zabbix server
來運行。Proxy
會將所有數據暫存于本地,然后同一轉發到Zabbix Server上
Proxy只需要一條TCP鏈接,可以連接到Zabbix-server上即可。所以防火墻只需要添加一條Zabbix Proxy即可 我們可以參考上面的Zabbix Proxy圖
Proxy是需要使用單獨的數據庫
,所以不能將Server
和Agent
放在一起
Proxy說明:https://www.zabbix.com/documentation/3.0/manual/distributed_monitoring/proxies
安裝文檔:https://www.zabbix.com/documentation/3.0/manual/installation/install
官方文檔使用的是源碼安裝,因為方便我們使用yum安裝,因為我們只有2臺,所以就用agent當做Proxy
[root@linux-node2 ~]# yum install -y zabbix-proxy zabbix-proxy-mysql mariadb-server我們需要啟動MySQL[root@linux-node2 ~]# systemctl start mariadb.service
我們還需要創建一個庫
mysqlcreate database zabbix_proxy character set utf8;grant all on zabbix_proxy.* to zabbix_proxy@localhost identified by 'zabbix_proxy';
我們需要導入數據
[root@linux-node2 ~]# cd /usr/share/doc/zabbix-proxy-mysql-3.0.5/[root@linux-node2 zabbix-proxy-mysql-3.0.5]# zcat schema.sql.gz | mysql -uzabbix_proxy -p zabbix_proxyEnter password: #密碼是:zabbix_proxy 是我們數據庫授權的密碼
檢查數據庫
mysqlshow databases;use zabbix_proxy;show tables;#查看是否含有數據
我們需要修改proxy
的配置文件
[root@linux-node2 zabbix-proxy-mysql-3.0.5]# vim /etc/zabbix/zabbix_proxy.conf Server=192.168.56.11Hostname=Zabbix proxyDBName=zabbix_proxy#數據庫名稱DBUser=zabbix_proxy#用戶名DBPassword=zabbix_proxy#用戶密碼配置文件中沒有配置的內容如下:(有需要可以配置)# ProxyLocalBuffer=0#數據保留的時間(小時為單位)# ProxyOfflineBuffer=1#連不上Server,數據要保留多久(小時為單位,默認1小時)# DataSenderFrequency=1#數據的發送時間間隔(默認是1秒)# StartPollers=5#啟動的線程數# StartIPMIPollers=0#啟動IPMI的線程數從這往下都是性能的監控,就不一次說明了。 上面都有中文注釋
過濾修改過的配置如下:
[root@linux-node2 zabbix-proxy-mysql-3.0.5]# grep '^[a-Z]' /etc/zabbix/zabbix_proxy.confServer=192.168.56.11Hostname=Zabbix proxyLogFile=/var/log/zabbix/zabbix_proxy.logLogFileSize=0PidFile=/var/run/zabbix/zabbix_proxy.pidDBName=zabbix_proxyDBUser=zabbix_proxyDBPassword=zabbix_proxySNMPTrapperFile=/var/log/snmptrap/snmptrap.logTimeout=4ExternalScripts=/usr/lib/zabbix/externalscriptsLogSlowQueries=3000
啟動
[root@linux-node2 ~]# systemctl start zabbix-proxy
查看proxy
進程
[root@linux-node2 ~]# netstat -lntupActive Internet connections (only servers)Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 15685/mysqld tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1073/sshd tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 2498/master tcp 0 0 0.0.0.0:10051 0.0.0.0:* LISTEN 15924/zabbix_proxy tcp6 0 0 :::44589 :::* LISTEN 9052/java tcp6 0 0 :::8080 :::* LISTEN 9052/java tcp6 0 0 :::22 :::* LISTEN 1073/sshd tcp6 0 0 :::8888 :::* LISTEN 9052/java tcp6 0 0 ::1:25 :::* LISTEN 2498/master tcp6 0 0 :::39743 :::* LISTEN 9052/java tcp6 0 0 :::10051 :::* LISTEN 15924/zabbix_proxy tcp6 0 0 127.0.0.1:8005 :::* LISTEN 9052/java tcp6 0 0 :::8009 :::* LISTEN 9052/java
Zabbix-proxy 監控10051端口,因為是代理就必須跟Server的端口相同,對于Agent Proxy就是Server
Zabbix Web 添加
點擊Add即可
我們需要將這臺主機的Server
設置為Proxy
編輯192.168.56.12
這臺主機,需要將Server的IP地址修改成自己的
因為現在是主動模式,我們只需要修改主動模式的Server即可
[root@linux-node2 ~]# vim /etc/zabbix/zabbix_agentd.conf ServerActive=192.168.56.12#配置文件修改完需要重啟[root@linux-node2 ~]# systemctl restart zabbix-agent
這時候我們就可以看到那個proxy
都管理了那些機器,做到方便管理的機制
proxy簡單的理解就是一個Server
完!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。