開源監(jiān)控系統(tǒng)Prometheus架構(gòu)說(shuō)明

Prometheus 是一套開源的系統(tǒng)監(jiān)控報(bào)警框架。它是由 google 前員工在 2012 年創(chuàng)建,作為社區(qū)開源項(xiàng)目進(jìn)行開發(fā),并于 2015 年正式發(fā)布。2016 年,Prometheus 正式加入 Cloud Native Computing Foundation。

Prometheus架構(gòu)如下:


架構(gòu)

從圖中可看到包含以下主要組件:

  • Prometheus Server: 用于收集和存儲(chǔ)時(shí)間序列數(shù)據(jù)。Prometheus Server是Prometheus組件中的核心部分,負(fù)責(zé)實(shí)現(xiàn)對(duì)監(jiān)控?cái)?shù)據(jù)的獲取,存儲(chǔ)以及查詢。 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 Server需要對(duì)采集到的監(jiān)控?cái)?shù)據(jù)進(jìn)行存儲(chǔ),Prometheus Server本身就是一個(gè)時(shí)序數(shù)據(jù)庫(kù),將采集到的監(jiān)控?cái)?shù)據(jù)按照時(shí)間序列的方式存儲(chǔ)在本地磁盤當(dāng)中。最后Prometheus Server對(duì)外提供了自定義的PromQL語(yǔ)言,實(shí)現(xiàn)對(duì)數(shù)據(jù)的查詢以及分析。
  • Client Library: 客戶端庫(kù),為需要監(jiān)控的服務(wù)生成相應(yīng)的 metrics 并暴露給 Prometheus server。當(dāng) Prometheus server 來(lái) pull 時(shí),直接返回實(shí)時(shí)狀態(tài)的 metrics。
  • Push Gateway: 主要用于短期的 jobs。由于這類 jobs 存在時(shí)間較短,可能在 Prometheus 來(lái) pull 之前就消失了。為此,這些 jobs 可以直接向 Prometheus server 端推送它們的 metrics。
  • Exporters: 用于暴露已有的第三方服務(wù)的 metrics 給 Prometheus。Exporter將監(jiān)控?cái)?shù)據(jù)采集的端點(diǎn)通過(guò)HTTP服務(wù)的形式暴露給Prometheus Server,Prometheus Server通過(guò)訪問該Exporter提供的Endpoint端點(diǎn),即可獲取到需要采集的監(jiān)控?cái)?shù)據(jù)。
  • Alertmanager: 從 Prometheus server 端接收到 alerts 后,會(huì)進(jìn)行去除重復(fù)數(shù)據(jù),分組,并路由到對(duì)方的接受方式,發(fā)出報(bào)警。常見的接收方式有:電子郵件,pagerduty 等。
  • WEB UI:Prometheus Server內(nèi)置的Express Browser UI,通過(guò)這個(gè)UI可以直接通過(guò)PromQL實(shí)現(xiàn)數(shù)據(jù)的查詢以及可視化。
  • 一些其他的工具。

Prometheus大概的工作流程是:

  1. Prometheus server 定期從配置好的 jobs 或者 exporters 中拉 metrics,或者接收來(lái)自 Pushgateway 發(fā)過(guò)來(lái)的 metrics,或者從其他的 Prometheus server 中拉 metrics。
  2. Prometheus server 在本地存儲(chǔ)收集到的 metrics,并運(yùn)行已定義好的 alert.rules,記錄新的時(shí)間序列或者向 Alertmanager 推送警報(bào)。
  3. Alertmanager 根據(jù)配置文件,對(duì)接收到的警報(bào)進(jìn)行處理,發(fā)出告警。
  4. 在圖形界面中,可視化采集數(shù)據(jù)。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容