在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Prometheus監控業務指標詳解

馬哥Linux運維 ? 來源:51CTO ? 2024-01-24 10:32 ? 次閱讀

Prometheus 監控業務指標

在 Kubernetes 已經成了事實上的容器編排標準之下,微服務的部署變得非常容易。但隨著微服務規模的擴大,服務治理帶來的挑戰也會越來越大。在這樣的背景下出現了服務可觀測性(observability)的概念。

在分布式系統里,系統的故障可能出現在任何節點,怎么能在出了故障的時候快速定位問題和解決問題,甚至是在故障出現之前就能感知到服務系統的異常,把故障扼殺在搖籃里。這就是可觀測性的意義所在。

可觀測性

可觀測性是由 logging, metrics, tracing 構建的, 簡稱為可觀測性三支柱。

3a4aac54-b9d5-11ee-8b88-92fbcf53809c.jpg

Lgging,展現的是應用運行而產生的事件或者程序在執行的過程中間產生的一些日志,可以詳細解釋系統的運行狀態,但是存儲和查詢需要消耗大量的資源。所以往往使用過濾器減少數據量。

Metrics,是一種聚合數值,存儲空間很小,可以觀察系統的狀態和趨勢,但對于問題定位缺乏細節展示。這個時候使用等高線指標等多維數據結構來增強對于細節的表現力。例如統計一個服務的 TBS 的正確率、成功率、流量等,這是常見的針對單個指標或者某一個數據庫的。

Tracing,面向的是請求,可以輕松分析出請求中異常點,但與 logging 有相同的問題就是資源消耗較大。通常也需要通過采樣的方式減少數據量。比如一次請求的范圍,也就是從瀏覽器或者手機端發起的任何一次調用,一個流程化的東西,我們需要軌跡去追蹤。

這篇文章討論的主題就是可觀測性中的 metrics。在 k8s 作為基礎設施的背景下,我們知道 K8s 本身是個復雜的容器編排系統,它本身的穩定運行至關重要。與之相伴的指標監控系統 Promethues 也已經成為了云原生服務下監控體系的事實標準。

相信大家對資源層面比如 CPU,Memory,Network;應用層面比如 Http 請求數,請求耗時等指標的監控都有所了解。那么業務層面的指標又怎么利用 Prometheus 去監控和告警呢?這就是這篇文章的核心內容。

以我們一個業務場景為例,在系統中有多種類型的 task 在運行,并且 task 的運行時間各異,task 本身有各種狀態包括待執行、執行中、執行成功、執行失敗等。如果想確保系統的穩定運行,我們必須對各個類型的 task 的運行狀況了如指掌。比如當前是否有任務擠壓,失敗任務是否過多,并且當超過閾值是否告警。

為了解決上述的監控告警問題,我們先得了解一下 Prometheus 的指標類型

指標

指標定義

在形式上,所有的指標(Metric)都通過如下格式標示:

{

指標的名稱(metric name)可以反映被監控樣本的含義(比如,http_request_total- 表示當前系統接收到的HTTP請求總量)。指標名稱只能由ASCII字符、數字、下劃線以及冒號組成并必須符合正則表達式[a-zA-Z_:][a-zA-Z0-9_:]*。

標簽(label)反映了當前樣本的特征維度,通過這些維度Prometheus可以對樣本數據進行過濾,聚合等。標簽的名稱只能由ASCII字符、數字以及下劃線組成并滿足正則表達式[a-zA-Z_][a-zA-Z0-9_]*。

指標類型

Prometheus定義了4種不同的指標類型(metric type):Counter(計數器)、Gauge(儀表盤)、Histogram(直方圖)、Summary(摘要)。

Counter

Counter類型的指標其工作方式和計數器一樣,只增不減(除非系統發生重置)。常見的監控指標,如http_requests_total,node_cpu都是 Counter 類型的監控指標。一般在定義Counter類型指標的名稱時推薦使用_total作為后綴。

通過 counter 指標我們可以和容易的了解某個事件產生的速率變化。

例如,通過rate()函數獲取HTTP請求量的增長率:

rate(http_requests_total[5m])

Gauge

Gauge類型的指標側重于反應系統的當前狀態。因此這類指標的樣本數據可增可減。常見指標如:node_memory_MemFree(主機當前空閑的內容大小)、node_memory_MemAvailable(可用內存大小)都是Gauge類型的監控指標。

通過Gauge指標,我們可以直接查看系統的當前狀態

node_memory_MemFree

Summary

Summary 主用用于統計和分析樣本的分布情況。比如某 Http 請求的響應時間大多數都在 100 ms 內,而個別請求的響應時間需要 5s,那么這中情況下統計指標的平均值就不能反映出真實情況。而如果通過 Summary 指標我們能立馬看響應時間的9分位數,這樣的指標才是有意義的。

例如

# HELP go_gc_duration_seconds A summary of the pause duration of garbage collection cycles.
# TYPE go_gc_duration_seconds summary
go_gc_duration_seconds{quantile="0"} 3.98e-05
go_gc_duration_seconds{quantile="0.25"} 5.31e-05
go_gc_duration_seconds{quantile="0.5"} 6.77e-05
go_gc_duration_seconds{quantile="0.75"} 0.0001428
go_gc_duration_seconds{quantile="1"} 0.0008099
go_gc_duration_seconds_sum 0.0114183
go_gc_duration_seconds_count 85

Histogram

Histogram 類型的指標同樣用于統計和樣本分析。與 Summary 類型的指標相似之處在于 Histogram 類型的樣本同樣會反應當前指標的記錄的總數(以_count作為后綴)以及其值的總量(以_sum作為后綴)。不同在于 Histogram 指標直接反應了在不同區間內樣本的個數,區間通過標簽len進行定義。同時對于Histogram的指標,可以通過histogram_quantile()函數計算出其值的分位數。

例如

# HELP prometheus_http_response_size_bytes Histogram of response size for HTTP requests.
# TYPE prometheus_http_response_size_bytes histogram
prometheus_http_response_size_bytes_bucket{handler="/",le="100"} 1
prometheus_http_response_size_bytes_bucket{handler="/",le="1000"} 1
prometheus_http_response_size_bytes_bucket{handler="/",le="10000"} 1
prometheus_http_response_size_bytes_bucket{handler="/",le="100000"} 1
prometheus_http_response_size_bytes_bucket{handler="/",le="1e+06"} 1
prometheus_http_response_size_bytes_bucket{handler="/",le="+Inf"} 1
prometheus_http_response_size_bytes_sum{handler="/"} 29
prometheus_http_response_size_bytes_count{handler="/"} 1

應用指標監控

暴露指標

Prometheus 最常用的方式是通過 pull 去抓取 metrics。所以我們首先在服務通過/metrics接口暴露指標,這樣 Promethues server 就能通過 http 請求抓取到我們的業務指標。

接口示例

server := gin.New()
server.Use(middlewares.AccessLogger(), middlewares.Metric(), gin.Recovery())




server.GET("/health", func(c *gin.Context) {
    c.JSON(http.StatusOK, gin.H{        "message": "ok",
    })
})




server.GET("/metrics", Monitor)func Monitor(c *gin.Context) {
    h := promhttp.Handler()
    h.ServeHTTP(c.Writer, c.Request)
}

定義指標

為了方便理解,這里選取了三種類型和兩種業務場景的指標
示例

var (    
    //HTTPReqDuration metric:http_request_duration_seconds
    HTTPReqDuration *prometheus.HistogramVec    
    //HTTPReqTotal metric:http_request_total
    HTTPReqTotal *prometheus.CounterVec    
    // TaskRunning metric:task_running
    TaskRunning *prometheus.GaugeVec
)




func init() {
    // 監控接口請求耗時
    // 指標類型是 Histogram
    HTTPReqDuration = prometheus.NewHistogramVec(prometheus.HistogramOpts{
        Name:    "http_request_duration_seconds",
        Help:    "http request latencies in seconds",
        Buckets: nil,
    }, []string{"method", "path"})
    // "method"、"path" 是 label




    // 監控接口請求次數
    // 指標類型是 Counter
    HTTPReqTotal = prometheus.NewCounterVec(prometheus.CounterOpts{
        Name: "http_requests_total",
        Help: "total number of http requests",
    }, []string{"method", "path", "status"})    // "method"、"path"、"status" 是 label




    // 監控當前在執行的 task 數量
    // 監控類型是 Gauge
    TaskRunning = prometheus.NewGaugeVec(prometheus.GaugeOpts{
        Name: "task_running",
        Help: "current count  of running task",
    }, []string{"type", "state"})
    // "type"、"state" 是 label




    prometheus.MustRegister(
        HTTPReqDuration,
        HTTPReqTotal,
        TaskRunning,
    )
}

通過上述的代碼我們就定義并且注冊了我們的想要監控的指標。

生成指標

示例

start := time.Now()
c.Next()




duration := float64(time.Since(start)) / float64(time.Second)




path := c.Request.URL.Path




// 請求數加1
controllers.HTTPReqTotal.With(prometheus.Labels{    
    "method": c.Request.Method,    
    "path":   path,    
    "status": strconv.Itoa(c.Writer.Status()),
}).Inc()




//  記錄本次請求處理時間
controllers.HTTPReqDuration.With(prometheus.Labels{    
    "method": c.Request.Method,    
    "path":   path,
}).Observe(duration)




// 模擬新建任務
controllers.TaskRunning.With(prometheus.Labels{    
    "type":  shuffle([]string{"video", "audio"}),    
    "state": shuffle([]string{"process", "queue"}),
}).Inc()




// 模擬任務完成
controllers.TaskRunning.With(prometheus.Labels{    
    "type":  shuffle([]string{"video", "audio"}),    
    "state": shuffle([]string{"process", "queue"}),
}).Dec()

抓取指標

Promethues 抓取 target 配置

# 抓取間隔
scrape_interval: 5s




# 目標
scrape_configs:
  - job_name: 'prometheus'
    static_configs:
      - targets: ['prometheus:9090']
  - job_name: 'local-service'
    metrics_path: /metrics
    static_configs:
      - targets: ['host.docker.internal:8000']

在實際應用中靜態配置 target 地址不太適用,在 k8s 下 Promethues通過與 Kubernetes API 集成目前主要支持5種服務發現模式,分別是:Node、Service、Pod、Endpoints、Ingress。

指標展示如下圖:

3a5811e6-b9d5-11ee-8b88-92fbcf53809c.jpg

3a6f8db2-b9d5-11ee-8b88-92fbcf53809c.jpg

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10873

    瀏覽量

    212038
  • 程序
    +關注

    關注

    117

    文章

    3788

    瀏覽量

    81111
  • 容器
    +關注

    關注

    0

    文章

    495

    瀏覽量

    22072
  • Prometheus
    +關注

    關注

    0

    文章

    27

    瀏覽量

    1717

原文標題:輕松駕馭!Prometheus 如何監控指標,快速定位故障

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Prometheus的架構原理從“監控”談起

    。 去年10月我們快速落地了一套易用、靈活、有亮點的業務監控平臺,其中使用到了Prometheus。從技術選型階段,Pr
    的頭像 發表于 10-10 15:47 ?4499次閱讀
    <b class='flag-5'>Prometheus</b>的架構原理從“<b class='flag-5'>監控</b>”談起

    Prometheus的基本原理與開發指南

    ? 導讀??? ? 本文由梯度科技云管研發部高級工程師周宇明撰寫,共分為7章,緊密圍繞Prometheus的基本原理與開發指南展開介紹: 監控系統概述 Prometheus入門 PromQL入門
    的頭像 發表于 11-09 10:45 ?1139次閱讀
    <b class='flag-5'>Prometheus</b>的基本原理與開發指南

    prometheus監控服務的整個流程介紹

    服務,端口為9098,并且監聽RabbitMQ的15672接口,獲取其中的指標數據,轉換成prometheus可以識別的metrics;如果需要對業務進行監控,這時候就需要自定義
    發表于 12-23 17:34

    指標監控體系如何建設

    、數據產品、數倉甚至是負責埋點的開發溝通,所以對于業務達到一定復雜度和指標達到一定量級的情況下,采用人肉運維的方式顯然是事倍功半的,搭建一套指標監控體系來保證產出數據的時效性和數據質量
    的頭像 發表于 09-26 10:39 ?1943次閱讀
    <b class='flag-5'>指標</b><b class='flag-5'>監控</b>體系如何建設

    django-prometheus數據監控

    django-prometheus.zip
    發表于 04-26 11:07 ?1次下載
    django-<b class='flag-5'>prometheus</b>數據<b class='flag-5'>監控</b>

    Prometheus服務監控系統

    prometheus.zip
    發表于 04-26 10:23 ?3次下載
    <b class='flag-5'>Prometheus</b>服務<b class='flag-5'>監控</b>系統

    使用Thanos+Prometheus+Grafana構建監控系統

    對于彈性伸縮和高可用的系統來說,一般有大量的指標數據需要收集和存儲,如何為這樣的系統打造一個監控方案呢?本文介紹了如何使用 Thanos+Prometheus+Grafana 構建監控
    的頭像 發表于 05-05 21:14 ?2650次閱讀

    prometheus-book Prometheus操作指南

    ./oschina_soft/prometheus-book.zip
    發表于 05-16 09:11 ?5次下載
    <b class='flag-5'>prometheus</b>-book <b class='flag-5'>Prometheus</b>操作指南

    監控神器:Prometheus

    Prometheus發展速度很快,12年開發完成,16年加入CNCF,成為繼K8s 之后第二個CNCF托管的項目,目前Github 42k的,而且社區很活躍,維護頻率很高,基本穩定在1個月1個小版本的迭代速度。
    的頭像 發表于 07-31 11:55 ?1204次閱讀

    關于Prometheus監控系統相關的知識體系

    今天浩道跟大家分享關于Prometheus監控系統相關的知識體系,讓你通過本文可以大體掌握其相關知識體系!
    的頭像 發表于 10-20 09:06 ?1215次閱讀

    prometheus下載安裝教程

    Prometheus 是一個開放性的監控解決方案,用戶可以非常方便的安裝和使用 Prometheus 并且能夠非常方便的對其進行擴展。 在Prometheus的架構設計中,
    的頭像 發表于 01-13 16:07 ?8062次閱讀
    <b class='flag-5'>prometheus</b>下載安裝教程

    基于kube-prometheus的大數據平臺監控系統設計

    本文介紹了如何基于 kube-prometheus 設計一個監控系統, 以靈活簡單的方式對 kubernetes 上的應用進行指標采集,并實現監控報警功能。
    的頭像 發表于 05-30 17:02 ?681次閱讀

    40個步驟安裝部署Prometheus監控系統

    Prometheus是一套開源的監控&報警&時間序列數據庫的組合,起始是由SoundCloud公司開發的。隨著發展,越來越多公司和組織接受采用Prometheus,社區也十分活躍,他們便將它獨立成開源項目,并且有公司來運作。
    的頭像 發表于 08-14 11:53 ?5.2w次閱讀
    40個步驟安裝部署<b class='flag-5'>Prometheus</b><b class='flag-5'>監控</b>系統

    基于Prometheus開源的完整監控解決方案

    每一個被 Prometheus 監控的服務都是一個 Job,Prometheus 為這些 Job 提供了官方的 SDK ,利用這個 SDK 可以自定義并導出自己的業務
    發表于 10-18 09:15 ?498次閱讀
    基于<b class='flag-5'>Prometheus</b>開源的完整<b class='flag-5'>監控</b>解決方案

    什么是Kubernetes CoreDNS?如何監控 CoreDNS?

    如果您在 Kubernetes 中運行您的工作負載,并且您不知道如何監控 CoreDNS,請繼續閱讀本文:如何使用 Prometheus 來抓取 CoreDNS 指標,您應該檢查哪些指標
    發表于 10-30 09:55 ?2237次閱讀
    什么是Kubernetes CoreDNS?如何<b class='flag-5'>監控</b> CoreDNS?
    主站蜘蛛池模板: 午夜毛片网站| 波多野结衣50连精喷在线| 在线黄色免费| 视频一二三区| 免费看啪| 国产精品9999| 在线免费视频网站| 国产片18在线观看| 1024 在线观看视频免费| videosxxoo18在线| 在线免费看视频| 黑人40厘米全进去xxxx猛交| 久久天天躁狠狠躁夜夜不卡| 欧美午夜视频| 97射射| 亚洲深夜| 4438x成人网最大色成网站| 国产精品福利午夜h视频| 1024你懂的在线观看| 亚洲资源最新版在线观看| 国产成人高清精品免费5388密| 亚洲国产精品国产自在在线| 国产男女免费视频| 四虎最新永久在线精品免费| 一级特黄aa大片免费播放视频| 网站在线你懂的| 欧美一级黄色片| 日本黄免费| 国产三及| 国产va在线观看| 国产成人mv在线观看入口视频 | 欧美日韩性大片| 成人aaa| 起碰成人免费公开网视频| 四虎国产精品永久在线| 性色视频在线观看| 五月婷婷婷| 羞羞色男人的天堂伊人久久| 日本特级黄色大片| 欧美特级黄| 在线视频一本|