溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Prometheus的工作原理是什么

發(fā)布時(shí)間:2021-01-25 15:42:22 來(lái)源:億速云 閱讀:1097 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

今天就跟大家聊聊有關(guān)Prometheus的工作原理是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

1. Prometheus 介紹

Prometheus是一套開(kāi)源的系統(tǒng)監(jiān)控報(bào)警框,相比Nagios或者Zabbix擁有如下優(yōu)點(diǎn)

1.1 易管理性

Prometheus: Prometheus核心部分只有一個(gè)單獨(dú)的二進(jìn)制文件,可直接在本地工作,不依賴(lài)于分布式存儲(chǔ)。

1.2 業(yè)務(wù)數(shù)據(jù)相關(guān)性

Prometheus:監(jiān)控服務(wù)的運(yùn)行狀態(tài),基于Prometheus豐富的Client庫(kù),用戶(hù)可以輕松的在應(yīng)用程序中添加對(duì)Prometheus的支持,從而讓用戶(hù)可以獲取服務(wù)和應(yīng)用內(nèi)部真正的運(yùn)行狀態(tài)。

1.3 高效:

單一Prometheus可以處理數(shù)以百萬(wàn)的監(jiān)控指標(biāo);每秒處理數(shù)十萬(wàn)的數(shù)據(jù)點(diǎn)。

1.4 易于伸縮:

通過(guò)使用功能分區(qū)(sharing)+聯(lián)邦集群(federation)可以對(duì)Prometheus進(jìn)行擴(kuò)展,形成一個(gè)邏輯集群;Prometheus提供多種語(yǔ)言的客戶(hù)端SDK,這些SDK可以快速讓?xiě)?yīng)用程序納入到Prometheus的監(jiān)控當(dāng)中。

1.5 良好的可視化:

Prometheus除了自帶有Prometheus UI,Grafana可視化工具也提供了完整的Proetheus支持

2. Prometheus 框架圖

Prometheus的工作原理是什么

3. Prometheus 組件介紹

3.1 Prometheus Server:

Prometheus Sever是Prometheus組件中的核心部分,負(fù)責(zé)實(shí)現(xiàn)對(duì)監(jiān)控?cái)?shù)據(jù)的獲取,存儲(chǔ)及查詢(xún)。Prometheus Server可以通過(guò)靜態(tài)配置管理監(jiān)控目標(biāo),也可以配合使用Service Discovery的方式動(dòng)態(tài)管理監(jiān)控目標(biāo),并從這些監(jiān)控目標(biāo)中獲取數(shù)據(jù)。其次Prometheus Sever需要對(duì)采集到的數(shù)據(jù)進(jìn)行存儲(chǔ),Prometheus Server本身就是一個(gè)實(shí)時(shí)數(shù)據(jù)庫(kù),將采集到的監(jiān)控?cái)?shù)據(jù)按照時(shí)間序列的方式存儲(chǔ)在本地磁盤(pán)當(dāng)中。Prometheus Server對(duì)外提供了自定義的PromQL,實(shí)現(xiàn)對(duì)數(shù)據(jù)的查詢(xún)以及分析。另外Prometheus Server的聯(lián)邦集群能力可以使其從其他的Prometheus Server實(shí)例中獲取數(shù)據(jù)。

3.2 Exporters:

Exporter將監(jiān)控?cái)?shù)據(jù)采集的端點(diǎn)通過(guò)HTTP服務(wù)的形式暴露給Prometheus Server,Prometheus Server通過(guò)訪問(wèn)該Exporter提供的Endpoint端點(diǎn),即可以獲取到需要采集的監(jiān)控?cái)?shù)據(jù)??梢詫xporter分為2類(lèi):
直接采集:這一類(lèi)Exporter直接內(nèi)置了對(duì)Prometheus監(jiān)控的支持,比如cAdvisor,Kubernetes,Etcd,Gokit等,都直接內(nèi)置了用于向Prometheus暴露監(jiān)控?cái)?shù)據(jù)的端點(diǎn)。
間接采集:原有監(jiān)控目標(biāo)并不直接支持Prometheus,因此需要通過(guò)Prometheus提供的Client Library編寫(xiě)該監(jiān)控目標(biāo)的監(jiān)控采集程序。例如:Mysql Exporter,JMX Exporter,Consul Exporter等。

3.3 AlertManager:

在Prometheus Server中支持基于Prom QL創(chuàng)建告警規(guī)則,如果滿(mǎn)足Prom QL定義的規(guī)則,則會(huì)產(chǎn)生一條告警。在AlertManager從 Prometheus server 端接收到 alerts后,會(huì)進(jìn)行去除重復(fù)數(shù)據(jù),分組,并路由到對(duì)收的接受方式,發(fā)出報(bào)警。常見(jiàn)的接收方式有:電子郵件,pagerduty,webhook 等。

3.4 PushGateway:

Prometheus數(shù)據(jù)采集基于Prometheus Server從Exporter pull數(shù)據(jù),因此當(dāng)網(wǎng)絡(luò)環(huán)境不允許Prometheus Server和Exporter進(jìn)行通信時(shí),可以使用PushGateway來(lái)進(jìn)行中轉(zhuǎn)。通過(guò)PushGateway將內(nèi)部網(wǎng)絡(luò)的監(jiān)控?cái)?shù)據(jù)主動(dòng)Push到Gateway中,Prometheus Server采用針對(duì)Exporter同樣的方式,將監(jiān)控?cái)?shù)據(jù)從PushGateway pull到Prometheus Server。

4. Prometheus的工作流:

4.1 Prometheus server定期從配置好的jobs或者exporters中拉取metrics,或者接收來(lái)自 Pushgateway發(fā)送過(guò)來(lái)的metrics,或者從其它的Prometheus server中拉metrics。

4.2 Prometheus server在本地存儲(chǔ)收集到的metrics,并運(yùn)行定義好的alerts.rules,記錄新的時(shí)間序列或者向Alert manager推送警報(bào)。

4.3 Alertmanager根據(jù)配置文件,對(duì)接收到的警報(bào)進(jìn)行處理,發(fā)出告警。

4.4 在圖形界面中,可視化采集數(shù)據(jù)。

看完上述內(nèi)容,你們對(duì)Prometheus的工作原理是什么有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI