使用Prometheus監控Cloudflare的全球網絡

Matt Bostock在SRECON 2017歐洲大會的演講中,介紹了如何使用Prometheus實現對CloudFlare分布于全球的架構和網絡的監控。Prometheus是一種基于度量進行監控的工具,CloudFlare是一家CDN、DNS和DDoS防御(Mitigation)服務提供商。

\\

基于度量的開源監控項目Prometheus最早推出于2012年,它是CNCF(原生云計算基金會,Cloud Native Computing Foundation)的成員。Prometheus的動態配置和查詢語言PromQL支持用戶編寫對告警的復雜查詢。CloudFlare提供CDN(內容分發網絡,Content Delivery Network)、分布式DNS和DDoS防御服務,這意味著其架構已擴展到全球范圍。監控這樣的架構及網絡無疑是一件復雜的工作。在演講中,Bostock介紹了Prometheus在其中發揮的作用。在CloudFlare,前期部署的Nagios的職能已有87%被Prometheus所替代。

\\

CloudFlare提供類似于Anycast所提供的CDN服務。Anycast DNS使得DNS查詢可以被最接近用戶的服務器所處理,Anycast HTTP使得內容可以從距離用戶最近的服務提供。作為原始Web站點和用戶之間的中介,CloudFlare還檢查訪問者的流量中是否存在有威脅的模式。它提供了跨150個國家的116個數據中心,每秒處理500萬次HTTP請求,120萬次DNS請求,占全球因特網請求的10%。每個入網點(PoP,Point-Of-Presence)提供HTTP、DNS、DDoS防御和鍵值存儲服務。截至演講時,有188臺運行在生產環境中的Prometheus服務器需要監控。

\\

d0e42317a03193328f141a0be178c7b0.png

\\

圖片來源:https://promcon.io/2017-munich/talks/monitoring-cloudflares-planet-scale-edge-network-with-prometheus/

\\

Prometheus是基于度量的,也就是說它采集時序度量,并基于度量構建其余的特性。它工作于Pull模式下,每臺監控服務器運行一個稱作“exporter”的進程,通過HTTP發布所采集的度量。CloudFlare為每個服務域部署了一個exporter,使用它們采集系統(例如CPU、內存、TCP、磁盤等)、網絡(例如HTTP、Ping等)、本地匹配(錯誤信息)和容器/命名空間的度量。其中,exporter使用了Google的開源項目cadvisor采集容器/命名空間的度量。Prometheus并不會永久地保存所有數據,因為它更側重于“此時此地”(here-and-now)的監控情況。數據不做下采樣,并在CloudFlare配置中保存15天。

\\

在CloudFlare的核心數據中心,服務包括日志訪問、分析業務,以及使用Marathon、Mesos、Chronos、Docker、Sentry、Ceph(用于存儲)、Kafka、Spark、Elasticsearch和Kibana等技術棧構建的API。Prometheus在每個PoP通過exporter查詢服務器和服務獲取度量。每個PoP的高可用性是由使用多個Prometheus服務提供的。

\\

Prometheus的報警管理稱為“Alertmanager”。CloudFlare的部署中包括一個Alermanager,由每個Prometheus服務器推送事件,并考慮了配置的高可用性。報警基于歷史數據做測試,確保服務的正確執行的。Bosun等新興監控工具也包括類似的特性。為提供更好的報警服務,其它的一些特性還包括了描述性的名稱、簡單易用性和一些可使接收者立刻采取行動的信息。

\\

CloudFlare團隊使用jiralerts實現JIRA工單系統與Alertmanager的集成。JIRA可以用戶定制工作流,使得報警監控中可以包括一些監控工作流特定的用戶定制狀態。另一個稱為alertmanagere2s的工具接收報警,并將報警信息集成到Elasticsearch索引中,用于進一步的檢索和分析。CloudFlare已為Alertmanger構建了自己的儀表盤,稱為“unsee”。

\\

那么Prometheus是如何監控自身情況的?這有兩種實現方法。一種是混合方法,即在同一數據中心中,由一個Prometheus去監控另一個Prometheus。另一種方法是自頂向下的方法,由頂層Prometheus服務器監控位于數據中心層面的Prometheus服務器。

\\

CloudFlare SRE團隊的經驗是,盡早對環境和集群等的標簽和組身份做標準化;其它一些經驗是關于如何創建可視化,以及從同行和利益相關者生成買入。經驗指出,團隊的盡早參與將有助于服務與監控系統的更快整合。而報警本身則需要多次迭代進行調整和改進,這是一個開展中的過程。

\\

查看英文原文: Monitoring Cloudflare's Global Network Using Prometheus

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/540384.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/540384.shtml
英文地址,請注明出處:http://en.pswp.cn/news/540384.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

[轉載] Java-forEach增強for循環是值傳遞規則詳解

參考鏈接: Java中的for-each循環 1. 引入 正如Java語法意義,變量的傳遞只有值傳遞,雖然變量分為引用變量和基本類型變量,前者更像C中的地址概念。 在學習Lambda表達式的時候,遇到了試圖在增強for循環中對原鏈表元素重…

開始吧

2019獨角獸企業重金招聘Python工程師標準>>> 寫C三年有余,在技術方面也算小有所成。準備在這里分享一些C進階、Python、Golang技術文章。 CSDN博客地址: http://blog.csdn.net/godmaycry 以后博客同步更新。 轉載于:https://my.oschina.net/u…

[轉載] 常用應屆生Java開發筆試面試題(更新中)

參考鏈接: Java中的循環的重要事項 Java開發面試題 Java基礎篇Java8大基本數據類型Java的三大特性面向對象如果讓你推銷一款Java產品,你會怎么推銷呢?(java的特點)JVM與字節碼JDK與JREStringBuilder和StringBuffer的區…

java/javascript 時間操作工具類

一、java 時間操作工具類 import org.springframework.util.StringUtils;import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.List;/*** 時間操作工具類** author zwq**/ public …

[轉載] java語言程序設計-基礎篇

參考鏈接: Java中的決策制定(if,if-else,switch,break,continue,jump) 第1章,計算機、程序和Java概述 包括【每個java初學者都應該搞懂的問題】 http://blog.csdn.net/haobo920/article/detai…

Exchange server 2013(十四)WSUS部署及組策略設置(2)

我們繼續上一節未完的博客,繼續我們的WSUS設置。[上一章節標題:Exchange server 2013(十四)WSUS部署及組策略設置(1) 網址:http://1183839.blog.51cto.com/blog/1173839/1182366] 首先單擊自動審批,來修改審批規則,也就是說當wsus偵測到新的更…

[轉載] Python中的switch語句的替代品

參考鏈接: Java中的switch語句 Python 中沒有 switch語句。 一般用if-else 語句可以替代switch語句,今天學習了使用字典的映射來代替switch語句。Mark一下 day 8; def get_sunday(): return sunday def get_monday(): return monday def get_tues…

“□” 表情無法在 Android 設備顯示? 快試試 EmojiCompact 表情兼容庫

有了支持庫 v26 下的 Compact 庫,基于 API 19 及更高版本開發的應用就能獲得 emoji 的向下兼容,再也不會看到顯示失敗的 “豆腐塊” 啦。如要使用 EmojiCompact,需要在應用啟動時通過下載或者打包字體來初始化庫。通過集成小插件,…

[轉載] jstl獲取Parameter參數及switch使用

參考鏈接&#xff1a; Java中的字符串使用switch <% taglib uri"/WEB-INF/tld/c.tld" prefix"c" %> param 獲取 Parameter參數 <c:choose> <c:when test"${empty param.name}"> Please enter your name. …

syslinux 制作多系統啟動U盤

syslinux 制作多系統啟動U盤標簽&#xff1a;u盤使用 syslinux 制作多系統啟動U盤 syslinux 能加載虛擬內存盤&#xff0c;能引導各種鏡像文件&#xff0c;適合用于制作多系統啟動U盤&#xff0c; 但是我按照網上說的步驟&#xff0c;總是不能制作成功&#xff1a; 1. 格式化…

[轉載] JAVA基礎----java中E,T,?的區別?

batch_size 1 layout "NHWC" target tvm.target.Target("cuda") dtype "float32" log_file "%s-%s-B%d.json" % (network, layout, batch_size)

用MATLAB結合四種方法搜尋羅馬尼亞度假問題

選修了cs的AI課&#xff0c;開始有點不適應&#xff0c;只能用matlab硬著頭皮上了&#xff0c;不過matlab代碼全網僅此一份&#xff0c;倒有點小自豪。 一、練習題目 分別用寬度優先、深度優先、貪婪算法和 A*算法求解“羅馬利亞度假問題”。具體地圖我這里不給出了&#xff0c…

[轉載] Java中文與ASCII碼的轉換

參考鏈接&#xff1a; 擴展Java中的原始轉換 今天在研究Java中編碼的時候&#xff0c;看到了Java中ascii碼的強大。寫了一個CoderUtils.java&#xff0c;以后會擴展它。 package com.xingxd.study.test; import java.io.File; import java.io.FileWriter; import java.io.I…

[轉]Paul Adams:為社交設計

為社交設計 Strong, Weak, and Temporary Ties by Paul Adams on 2010/04/09 PS&#xff1a;作者Paul Adams Facebook全球品牌體驗總監 電話和手機聚集十億用戶用了15年的時間&#xff0c;而Facebook只用了9個月。我們看到越來越多的人開始用在線社交網絡&#xff0c;這種網絡好…

[轉載] Java中日期格式轉換

參考鏈接&#xff1a; Java中的類型轉換和示例 Code: /** * 字符串轉換為java.util.Date<br> * 支持格式為 yyyy.MM.dd G at hh:mm:ss z 如 2002-1-1 AD at 22:10:59 PSD<br> * yy/MM/dd HH:mm:ss 如 2002/1/1 17:55:00<br> * yy/MM/dd HH:…

Android Framework中的Application Framework層介紹

Android的四層架構相比大家都很清楚&#xff0c;老生常談的說一下分別為&#xff1a; Linux2.6內核層&#xff0c;核心庫層&#xff0c;應用框架層&#xff0c;應用層。我今天重點介紹一下應用框架層Framework。 Framework層為我們開發應用程序提供了非常多的API&#xff0c;我…

[轉載] java注釋

參考鏈接&#xff1a; Java注釋 Java注釋 java中注釋有三種&#xff1a;這些都稱之為java doc標記&#xff0c;含義如下&#xff1a; java中注釋有三種&#xff1a; 單行注釋 //注釋的內容&#xff0c;多行注釋 /…注釋的內容…/&#xff0c;文檔注釋 /**…注釋的內容….*/。…

環路是怎樣形成的實例

環路是怎樣形成的一個由十多臺交換機組成的小型局域網&#xff0c;交換機大多是Cisco的中低端系列產品。某日突然出現問題&#xff1a;局域網內的主機之間相互ping時&#xff0c;都出現延時長、丟包現象&#xff0c;網絡應用奇慢無比。 觀察交換機設備&#xff0c;指示燈看不出…

[轉載] 《Python語言程序設計》課程筆記

參考鏈接&#xff1a; Python程式設計語言 文章目錄 第一部分 Python快速入門第1周 Python基本語法元素第2周 Python基本圖形繪制 第二部分 Python基礎語法第3周 基本數據類型3.1 數字類型及操作3.3 字符串類型及操作3.4 模塊2: time庫的使用 第4周 程序的控制結構4.1 程序的分…

ORACLE中創建如何創建表,并設置結構和默認值

使用select語句查看EMP表&#xff0c;根據COMM排序 默認情況下&#xff0c;空值會自動排列在尾部。 利用nulls last排序時將空值置底 利用nulls first排序時將空值置頂 例 創建一張出版社表 使用語句 create table 表名&#xff08;列名1 類型&#xff0c;列名2 類型&#xff0…