偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

自從上了 Prometheus 監(jiān)控,睡覺真“香”

系統(tǒng) 運維
Prometheus 本質(zhì)來說是一個基于數(shù)據(jù)的監(jiān)控系統(tǒng)。

背景

對很多人來說,未知、不確定、不在掌控的東西,會有潛意識的逃避。當我第一次接觸 Prometheus 的時候也有類似的感覺。對初學者來說, Prometheus 包含的概念太多了,門檻也太高了。

概念:Instance、Job、Metric、Metric Name、Metric Label、Metric Value、Metric Type(Counter、Gauge、Histogram、Summary)、DataType(Instant Vector、Range Vector、Scalar、String)、Operator、Function

馬老師說:“雖然阿里巴巴是全球最大的零售平臺,但阿里不是零售公司,是一家數(shù)據(jù)公司”。Prometheus 也是一樣,本質(zhì)來說是一個基于數(shù)據(jù)的監(jiān)控系統(tǒng)。

日常監(jiān)控

假設(shè)需要監(jiān)控 WebServerA 每個API的請求量為例,需要監(jiān)控的維度包括:服務(wù)名(job)、實例IP(instance)、API名(handler)、方法(method)、返回碼(code)、請求量(value)。

如果以SQL為例,演示常見的查詢操作:

查詢 method=put 且 code=200 的請求量(紅框)

SELECT * from http_requests_total WHERE code=”200” AND method=”put” AND created_at BETWEEN 1495435700 AND 1495435710;

查詢 handler=prometheus 且 method=post 的請求量(綠框)

SELECT * from http_requests_total WHERE handler=”prometheus” AND method=”post” AND created_at BETWEEN 1495435700 AND 1495435710;

查詢 instance=10.59.8.110 且 handler 以 query 開頭 的請求量(綠框)

SELECT * from http_requests_total WHERE handler=”query” AND instance=”10.59.8.110 AND created_at BETWEEN 1495435700 AND 1495435710;

通過以上示例可以看出,在常用查詢和統(tǒng)計方面,日常監(jiān)控多用于根據(jù)監(jiān)控的維度進行查詢與時間進行組合查詢。如果監(jiān)控100個服務(wù),平均每個服務(wù)部署10個實例,每個服務(wù)有20個API,4個方法,30秒收集一次數(shù)據(jù),保留60天。那么總數(shù)據(jù)條數(shù)為:100(服務(wù)) 10(實例) 20(API) 4(方法) 86400(1天秒數(shù))* 60(天) / 30(秒)= 138.24 億條數(shù)據(jù),寫入、存儲、查詢?nèi)绱肆考壍臄?shù)據(jù)是不可能在Mysql類的關(guān)系數(shù)據(jù)庫上完成的。因此 Prometheus 使用 TSDB 作為存儲引擎。

存儲引擎

TSDB 作為 Prometheus 的存儲引擎完美契合了監(jiān)控數(shù)據(jù)的應(yīng)用場景

  • 存儲的數(shù)據(jù)量級十分龐大
  • 大部分時間都是寫入操作
  • 寫入操作幾乎是順序添加,大多數(shù)時候數(shù)據(jù)到達后都以時間排序
  • 寫操作很少寫入很久之前的數(shù)據(jù),也很少更新數(shù)據(jù)。大多數(shù)情況在數(shù)據(jù)被采集到數(shù)秒或者數(shù)分鐘后就會被寫入數(shù)據(jù)庫
  • 刪除操作一般為區(qū)塊刪除,選定開始的歷史時間并指定后續(xù)的區(qū)塊。很少單獨刪除某個時間或者分開的隨機時間的數(shù)據(jù)
  • 基本數(shù)據(jù)大,一般超過內(nèi)存大小。一般選取的只是其一小部分且沒有規(guī)律,緩存幾乎不起任何作用
  • 讀操作是十分典型的升序或者降序的順序讀
  • 高并發(fā)的讀操作十分常見

那么 TSDB 是怎么實現(xiàn)以上功能的呢?

"labels": [{
"latency": "500"
}]
"samples":[{
"timestamp": 1473305798,
"value": 0.9
}]

原始數(shù)據(jù)分為兩部分 label, samples。前者記錄監(jiān)控的維度(標簽:標簽值),指標名稱和標簽的可選鍵值對唯一確定一條時間序列(使用 series_id 代表);后者包含包含了時間戳(timestamp)和指標值(value)。

series
^
. . . . . . . . . . . . server{latency="500"}
. . . . . . . . . . . . server{latency="300"}
. . . . . . . . . . . server{}
. . . . . . . . . . . .
v
<-------- time ---------->

TSDB 使用 timeseries:doc:: 為 key 存儲 value。為了加速常見查詢查詢操作:label 和 時間范圍結(jié)合。TSDB 額外構(gòu)建了三種索引:Series, Label Index 和 Time Index。

以標簽 latency 為例:

Series

存儲兩部分數(shù)據(jù)。一部分是按照字典序的排列的所有標簽鍵值對序列(series);另外一部分是時間線到數(shù)據(jù)文件的索引,按照時間窗口切割存儲數(shù)據(jù)塊記錄的具體位置信息,因此在查詢時可以快速跳過大量非查詢窗口的記錄數(shù)據(jù)

Label Index

每對 label 為會以 index:label: 為 key,存儲該標簽所有值的列表,并通過引用指向 Series 該值的起始位置。

Time Index

數(shù)據(jù)會以 index:timeseries:: 為 key,指向?qū)?yīng)時間段的數(shù)據(jù)文件

數(shù)據(jù)計算

強大的存儲引擎為數(shù)據(jù)計算提供了完美的助力,使得 Prometheus 與其他監(jiān)控服務(wù)完全不同。Prometheus 可以查詢出不同的數(shù)據(jù)序列,然后再加上基礎(chǔ)的運算符,以及強大的函數(shù),就可以執(zhí)行 metric series 的矩陣運算(見下圖)。

如此,Promtheus體系的能力不弱于監(jiān)控界的“數(shù)據(jù)倉庫”+“計算平臺”。因此,在大數(shù)據(jù)的開始在業(yè)界得到應(yīng)用,就能明白,這就是監(jiān)控未來的方向。

一次計算,處處查詢

當然,如此強大的計算能力,消耗的資源也是挺恐怖的。因此,查詢預(yù)計算結(jié)果通常比每次需要原始表達式都要快得多,尤其是在儀表盤和告警規(guī)則的適用場景中,儀表盤每次刷新都需要重復(fù)查詢相同的表達式,告警規(guī)則每次運算也是如此。因此,Prometheus提供了 Recoding rules,可以預(yù)先計算經(jīng)常需要或者計算量大的表達式,并將其結(jié)果保存為一組新的時間序列, 達到 一次計算,多次查詢的目的。

責任編輯:張燕妮 來源: 高效運維
相關(guān)推薦

2021-04-23 08:29:47

SkyWalking監(jiān)控系統(tǒng)

2025-07-28 09:36:45

2020-07-03 15:10:35

Java Rust 開發(fā)

2021-05-27 15:43:29

鴻蒙安卓和iOS

2022-06-01 17:47:24

運維監(jiān)控系統(tǒng)

2023-04-20 07:12:33

夜鶯監(jiān)控夜鶯

2022-05-18 08:32:05

服務(wù)監(jiān)控Prometheus開源

2020-12-30 08:09:46

運維Prometheus 監(jiān)控

2022-07-11 09:36:38

SpringJava開發(fā)

2022-05-19 08:21:02

vmalert監(jiān)控

2025-07-14 05:00:00

監(jiān)控系統(tǒng)工具

2022-11-08 00:00:00

監(jiān)控系統(tǒng)Prometheus

2022-07-08 08:00:31

Prometheus監(jiān)控

2023-10-09 07:31:25

2020-10-20 09:07:11

監(jiān)控PrometheusZabbix

2020-12-29 10:45:22

運維Prometheus-監(jiān)控

2022-12-13 08:01:06

監(jiān)控黑盒集成

2020-11-20 08:15:40

Grafana + P

2024-02-23 16:10:29

KubernetesPrometheus開源

2021-07-01 11:29:45

KubernetesGrafana監(jiān)控
點贊
收藏

51CTO技術(shù)棧公眾號