從統(tǒng)計(jì)意義上說,每次接受連接的時(shí)候,對(duì)于每個(gè)trapper進(jìn)程來說都有相同的概率獲得連接,***的結(jié)果就是所有連接在所有trapper進(jìn)程之間均衡分配。如果考慮每個(gè)連接中包含的數(shù)據(jù)量不均衡,那么當(dāng)某個(gè)trapper進(jìn)程接受的某個(gè)連接包含較多的數(shù)據(jù)時(shí),意味著該進(jìn)程需要花更多的時(shí)間來讀取和處理數(shù)據(jù),這就意味著下一次接受連接的時(shí)間被推遲。對(duì)于poller進(jìn)程,道理也是一樣,每個(gè)poller進(jìn)程都以相同的概率從Zabbixserver端的配置緩存接收到任務(wù),從而實(shí)現(xiàn)數(shù)據(jù)分配均衡。預(yù)處理進(jìn)程的工作模式與trapper進(jìn)程不同,預(yù)處理進(jìn)程采用manager-worker模式,即manager進(jìn)程是***的數(shù)據(jù)入口,負(fù)責(zé)從trapper和poller接收所有數(shù)據(jù),然后通過unix域套接字將數(shù)據(jù)分配給各個(gè)worker進(jìn)程處理。其分配的規(guī)則是,每次每個(gè)worker只分配一個(gè)數(shù)據(jù),只有當(dāng)worker完成前一個(gè)任務(wù)之后才會(huì)分配下一個(gè)任務(wù)。***,historysyncer進(jìn)程之間的數(shù)據(jù)均衡也是遵循機(jī)會(huì)均等的機(jī)制。其主要特點(diǎn)是,每個(gè)循環(huán)**多處理1000個(gè)監(jiān)控值,所以每次寫數(shù)據(jù)庫的監(jiān)控值也不會(huì)超過1000個(gè)。我們會(huì)發(fā)現(xiàn),總體的數(shù)據(jù)處理過程都基于監(jiān)控?cái)?shù)據(jù)之間的**性,從而可以靈活地在各個(gè)進(jìn)程之間調(diào)度。Zabbix如何實(shí)現(xiàn)對(duì)大流量監(jiān)控?cái)?shù)據(jù)的高效處理?企業(yè)級(jí)zabbix怎樣監(jiān)控網(wǎng)站
兩種消息格式均為文本格式,相較于使用二進(jìn)制格式,文本格式使得agent端的接口設(shè)計(jì)更簡單,從而為自定義agent開發(fā)提供了便利,可以吸納更多的監(jiān)控目標(biāo)轉(zhuǎn)向Zabbix。在tcp連接的管理方面,Zabbix的每個(gè)連接只處理一個(gè)請(qǐng)求,處理完就會(huì)關(guān)閉,無論在trapper進(jìn)程還是poller進(jìn)程中都是這樣。每個(gè)tcp連接的建立和關(guān)閉都意味著一定的開銷,但是這種模式也有優(yōu)點(diǎn),就是靈活性。每次連接只處理一個(gè)請(qǐng)求,意味著每個(gè)請(qǐng)求都可以在多個(gè)進(jìn)程之間重新調(diào)度。從而可以更好地在眾多進(jìn)程之間實(shí)現(xiàn)動(dòng)態(tài)均衡。退一步說,通過增加單個(gè)連接的數(shù)據(jù)量也能夠降低頻繁建立連接的成本。在擴(kuò)展性方面,除了可以通過增加進(jìn)程數(shù)量來增加數(shù)據(jù)吞吐量之外,Zabbix還支持多地址***,從而可以突破單套接字的吞吐量限制。品質(zhì)zabbix認(rèn)真負(fù)責(zé)集群節(jié)點(diǎn)發(fā)送到數(shù)據(jù)庫后端的心跳是非常小的消息,記錄在一個(gè)較小的Zabbix數(shù)據(jù)庫表中,故性能影響忽略不計(jì)。
1、Zabbix_Server:zabbix_server作為**組件,用來獲取agent存活情況和監(jiān)控?cái)?shù)據(jù)。所有的配置、統(tǒng)計(jì)、操作數(shù)據(jù)均通過server進(jìn)行存取到database;2、Zabbix_Database:用戶存儲(chǔ)所有的zabbix的配置信息、監(jiān)控?cái)?shù)據(jù)的數(shù)據(jù)庫;3、Zabbix_Web:zabbix的web界面,管理員通過web界面管理zabbix配置以及查看zabbix相關(guān)監(jiān)控信息,通常與zabbix_server運(yùn)行在同一臺(tái)主機(jī)上,也可以單獨(dú)部署在**的服務(wù)器上;4、Zabbix_Proxy:通常用于分布式監(jiān)控,代理zabbix_server收集部分被監(jiān)控的數(shù)據(jù)并統(tǒng)一發(fā)送給server端;(通常大于500臺(tái)主機(jī)需要使用)5、Zabbix_Agent:部署在被監(jiān)控主機(jī)上,負(fù)責(zé)收集被監(jiān)控主機(jī)的數(shù)據(jù),并發(fā)送給servre端或者proxy端;ZabbixServer、Proxy、Agent都有自己的配置文件以及l(fā)og文件,重要的參數(shù)需要在這里配置,后面會(huì)詳細(xì)說明。
監(jiān)控?cái)?shù)據(jù)的存儲(chǔ)是由historysyncer進(jìn)程負(fù)責(zé)寫入數(shù)據(jù)庫,historysyncer進(jìn)程應(yīng)對(duì)大流量數(shù)據(jù)的方式是,一方面通過批量插入來提高寫庫的效率,另一方面通過多進(jìn)程的方式來擴(kuò)展數(shù)據(jù)處理能力。在寫庫過程中,歷史數(shù)據(jù)寫入history表,即使數(shù)據(jù)變?yōu)槔鋽?shù)據(jù)也需要留在history表中供前端UI訪問。趨勢(shì)數(shù)據(jù)寫入trends表,相較于歷史數(shù)據(jù),趨勢(shì)數(shù)據(jù)的寫庫負(fù)載要低的多,是因?yàn)閷?duì)于每個(gè)監(jiān)控項(xiàng)來說,平均每小時(shí)只需要寫庫一次,其他時(shí)間只需要更新趨勢(shì)緩存,不需要寫庫。在historysyncer進(jìn)程的觸發(fā)器計(jì)算階段,主要訪問值緩存,但是如果值緩存不能命中則需要查詢history表,這種情況下就需要使用history表索引了??紤]索引對(duì)insert操作的影響,索引在提高查詢速度的同時(shí)也降低了寫入性能。觸發(fā)器計(jì)算之后生成的event信息也需要寫入數(shù)據(jù)庫,這些信息存儲(chǔ)在events表、problem、escalation等表中。因此,這些表的數(shù)據(jù)增長率取決于Zabbix生成的事件的數(shù)量,當(dāng)事件數(shù)量陡增時(shí),這些表的寫入壓力也會(huì)隨之增加。在數(shù)據(jù)存儲(chǔ)方面主要體現(xiàn)了熱數(shù)據(jù)和冷數(shù)據(jù)的轉(zhuǎn)換過程以及數(shù)據(jù)規(guī)模對(duì)讀寫性能的影響。Zabbix 優(yōu)缺點(diǎn)分別有哪些?
Prometheus將數(shù)據(jù)存儲(chǔ)在自己的時(shí)間序列數(shù)據(jù)庫(TSDB)中。Prometheus擁有自己的TSDB,可以接收和處理比許多其他監(jiān)控系統(tǒng)更多的指標(biāo)。Prometheus甚至可以使用毫秒分辨率時(shí)間戳寫入數(shù)據(jù)。Prometheus本身**多只能存儲(chǔ)14天的數(shù)據(jù),如需更長的數(shù)據(jù)存儲(chǔ)時(shí)間,您可以配置遠(yuǎn)程存儲(chǔ)。Zabbix使用外部數(shù)據(jù)庫來存儲(chǔ)數(shù)據(jù)。Zabbix數(shù)據(jù)庫必須在安裝期間創(chuàng)建。當(dāng)前支持以下數(shù)據(jù)庫:MySQL、PostgreSQL、Oracle、IBMDB2和SQLite。Prometheus和Zabbix的區(qū)別,必須要考慮到,Prometheus只存儲(chǔ)時(shí)間序列的值。它不適用于文本、日志或事件日志。不過可以通過Grafana的Loki與Prometheus一起使用,可以解決這個(gè)問題,但Zabbix可以提供開箱即用的基本功能,用于存儲(chǔ)一些文本、日志、分析設(shè)置觸發(fā)器。Zabbix 與 Prometheus 到底該如何選擇?企業(yè)級(jí)zabbix如何部署
Zabbix 6.2將又一次提升新用戶和老用戶的用戶體驗(yàn)。企業(yè)級(jí)zabbix怎樣監(jiān)控網(wǎng)站
zabbix支持監(jiān)控各種系統(tǒng)平臺(tái),包括Linux和Windows等主流操作系統(tǒng),也可以借助SNMP或者是SSH協(xié)議監(jiān)控路由交換設(shè)備。zabbix如果部署在服務(wù)器上,可以監(jiān)控其CPU、內(nèi)存、網(wǎng)絡(luò)性能等硬件參數(shù),也可以監(jiān)控具體的服務(wù)或者應(yīng)用程序、服務(wù)運(yùn)行情況及性能。硬件監(jiān)控:ZabbixIPMIInterface,通過IPMI接口進(jìn)行監(jiān)控,我們可以通過標(biāo)準(zhǔn)的IPMI硬件接口,監(jiān)控被監(jiān)控對(duì)象的物理特征,比如電壓、溫度、風(fēng)扇狀態(tài)、電源狀態(tài)等。系統(tǒng)監(jiān)控:ZabbixAgentInterface,通過的代理程序進(jìn)行監(jiān)控,與常見的master/agent模型類似,如果被監(jiān)控對(duì)象支持對(duì)應(yīng)的agent,推薦優(yōu)先這種方式。Java監(jiān)控:ZabbixJMXInterface,通過JMX進(jìn)行監(jiān)控,JMX(javamanagementextensions,即java管理擴(kuò)展),監(jiān)控JVM虛擬機(jī)時(shí),使用這種方法是非常不錯(cuò)的選擇。網(wǎng)絡(luò)設(shè)備監(jiān)控:ZabbixSNMPInterface,通過SNMP協(xié)議與被監(jiān)控對(duì)象進(jìn)行通信,SNMP協(xié)議的全稱為simplenetworkmanagementprotocol,被譯為簡單網(wǎng)絡(luò)管理協(xié)議,通常來說,我們無法在路由器、交換機(jī)這種硬件上安裝agent,但是這些硬件都支持SNMP協(xié)議。應(yīng)用服務(wù)監(jiān)控:ZabbixAgentUserParameterMySQL數(shù)據(jù)庫監(jiān)控:percona-monitoring-plulginsURL監(jiān)控:ZabbixWeb監(jiān)控企業(yè)級(jí)zabbix怎樣監(jiān)控網(wǎng)站
上海觀縱科技有限公司坐落于上海市奉賢區(qū)望園南路1288弄80號(hào)1904、1909室,是集設(shè)計(jì)、開發(fā)、生產(chǎn)、銷售、售后服務(wù)于一體,傳媒、廣電的服務(wù)型企業(yè)。公司在行業(yè)內(nèi)發(fā)展多年,持續(xù)為用戶提供整套webfunny前端監(jiān)控,webfunny前端埋點(diǎn),全鏈路應(yīng)用性能監(jiān)控,Argus-IT運(yùn)維監(jiān)控的解決方案。公司主要產(chǎn)品有webfunny前端監(jiān)控,webfunny前端埋點(diǎn),全鏈路應(yīng)用性能監(jiān)控,Argus-IT運(yùn)維監(jiān)控等,公司工程技術(shù)人員、行政管理人員、產(chǎn)品制造及售后服務(wù)人員均有多年行業(yè)經(jīng)驗(yàn)。并與上下游企業(yè)保持密切的合作關(guān)系。webfunny,walkingfunny,argus集中了一批經(jīng)驗(yàn)豐富的技術(shù)及管理專業(yè)人才,能為客戶提供良好的售前、售中及售后服務(wù),并能根據(jù)用戶需求,定制產(chǎn)品和配套整體解決方案。上海觀縱科技有限公司以先進(jìn)工藝為基礎(chǔ)、以產(chǎn)品質(zhì)量為根本、以技術(shù)創(chuàng)新為動(dòng)力,開發(fā)并推出多項(xiàng)具有競爭力的webfunny前端監(jiān)控,webfunny前端埋點(diǎn),全鏈路應(yīng)用性能監(jiān)控,Argus-IT運(yùn)維監(jiān)控產(chǎn)品,確保了在webfunny前端監(jiān)控,webfunny前端埋點(diǎn),全鏈路應(yīng)用性能監(jiān)控,Argus-IT運(yùn)維監(jiān)控市場(chǎng)的優(yōu)勢(shì)。