Zabbix是一個企業(yè)級的開源分布式監(jiān)控解決方案,由C語言編寫而成的底層架構(gòu)(server端和agent端),由一個團隊持續(xù)維護更新,軟件可以自由下載使用,運作團隊靠提供收費的技術(shù)支持贏利。
創(chuàng)新互聯(lián)建站致力于成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè),成都網(wǎng)站設(shè)計,集團網(wǎng)站建設(shè)等服務(wù)標準化,推過標準化降低中小企業(yè)的建站的成本,并持續(xù)提升建站的定制化服務(wù)水平進行質(zhì)量交付,讓企業(yè)網(wǎng)站從市場競爭中脫穎而出。 選擇創(chuàng)新互聯(lián)建站,就選擇了安全、穩(wěn)定、美觀的網(wǎng)站建設(shè)服務(wù)!1、Zabbix通過C/S模式采集數(shù)據(jù),通過B/S模式在web端展示和配置。
2、被監(jiān)控端:主機通過安裝agent方式采集數(shù)據(jù),網(wǎng)絡(luò)設(shè)備通過SNMP方式采集數(shù)據(jù)
3、Server端:通過收集SNMP和agent發(fā)送的數(shù)據(jù),寫入MySQL數(shù)據(jù)庫,再通過php+apache在web前端展示。
**1、server**
Zabbix Server需運行在LAMP(Linux+Apache+Mysql+PHP)環(huán)境下,對硬件要求低
**2、Agent**
目前已有的agent基本支持市面常見的OS,包含Linux、HPUX、Solaris、Sun、windows等
**3、SNMP**
支持各類常見的網(wǎng)絡(luò)設(shè)備
Agentd安裝在被監(jiān)控的主機上,Agent負責定期收集客戶端本地各項數(shù)據(jù),并發(fā)送至Zabbix Server端,Zabbix Server收到數(shù)據(jù),將數(shù)據(jù)存儲到數(shù)據(jù)庫中,用戶基于Zabbix WEB可以看到數(shù)據(jù)在前端展現(xiàn)圖像。當Zabbix監(jiān)控某個具體的項目,改項目會設(shè)置一個觸發(fā)器閾值,當被監(jiān)控的指標超過該觸發(fā)器設(shè)定的閾值,會進行一些必要的動作,動作包括:發(fā)送信息(郵件、微信、短信)、發(fā)送命令(SHELL 命令、Reboot、Restart、Install等)。
主動模式:由agent端主動收集信息發(fā)送給server端 工具是zabbix_sender
被動模式:由server端主動拉取信息 工具是zabbix_get
Zabbix agent:負責部署在被監(jiān)控主機上,把被監(jiān)控主機的數(shù)據(jù)傳送給zabbix server
Zabbix server:負責接收agent發(fā)送的信息,組織配置信息,統(tǒng)計配置信息和操作數(shù)據(jù)等
Zabbix database: 用于存儲zabbix的所有配置信息,監(jiān)控數(shù)據(jù)的數(shù)據(jù)庫
Zabbix web: zabbix的web界面,管理可以通過zabbix的web界面管理zabbix配置以及查看zabbix的監(jiān)控信息,可以獨一部署在一臺服務(wù)器上
Zabbix proxy:分布式環(huán)境中使用,zabbix proxy代表server端管理該區(qū)域中的信息收集,最終統(tǒng)一發(fā)往zabbix server
agent:通過專用的代理程序進行監(jiān)控
ssh/Telnet:通過遠程控制協(xié)議進行通訊
SNMP:通過SNMP協(xié)議與被監(jiān)控對象進行通訊,路由器和交換機支持
SNMP,其實也是一種agent
IPMI:通過IPMI接口進行監(jiān)控,通過IPMI硬件接口監(jiān)控,電壓,溫度,風扇,和電源狀態(tài)
JMX:通過(java management extensions Java管理擴展)監(jiān)控JVM虛擬機
**監(jiān)控數(shù)據(jù)被提交給zabbix proxy 再 提交給zabbix server**
在實際監(jiān)控架構(gòu)中,zabbix根據(jù)網(wǎng)絡(luò)環(huán)境、監(jiān)控規(guī)模等分了三種架構(gòu): server-client 、master-node-client、server-proxy-client三種 。
**1、server-client架構(gòu)**
也是zabbix的最簡單的架構(gòu),監(jiān)控機和被監(jiān)控機之間不經(jīng)過任何代理 ,直接由zabbix server和zabbix agentd之間進行數(shù)據(jù)交互。適用于網(wǎng)絡(luò)比較簡單,設(shè)備比較少的監(jiān)控環(huán)境 。
**2、server-proxy-client架構(gòu)**
其中proxy是server、client之間溝通的一個橋梁,proxy本身沒有前端,而且其本身并不存放數(shù)據(jù),只是將agentd發(fā)來的數(shù)據(jù)暫時存放,而后再提交給server 。該架構(gòu)經(jīng)常是和master-node-client架構(gòu)做比較的架構(gòu) ,一般適用于跨機房、跨網(wǎng)絡(luò)的中型網(wǎng)絡(luò)架構(gòu)的監(jiān)控。
**3、master-node-client架構(gòu)**
該架構(gòu)是zabbix最復(fù)雜的監(jiān)控架構(gòu),適用于跨網(wǎng)絡(luò)、跨機房、設(shè)備較多的大型環(huán)境 。每個node同時也是一個server端,node下面可以接proxy,也可以直接接client 。node有自已的配置文件和數(shù)據(jù)庫,其要做的是將配置信息和監(jiān)控數(shù)據(jù)向master同步,master的故障或損壞對node其下架構(gòu)的完整性。