中小研發團隊架構實踐之應用監控Metrics

来源:https://www.cnblogs.com/dotnet-arch-system/archive/2018/02/25/8469693.html
-Advertisement-
Play Games

一、Metrics簡介 應用監控系統Metrics由Metrics.NET+InfluxDB+Grafana組合而成,通過客戶端Metrics.NET在業務代碼中埋點,Metrics.NET會把收集到數據存儲在InfluxDB資料庫中,然後通過Grafana來展示監控數據。其中,InfluxDB服務 ...


一、Metrics簡介

       應用監控系統MetricsMetrics.NET+InfluxDB+Grafana組合而成通過客戶端Metrics.NET業務代碼中埋點,Metrics.NET會把收集到數據存儲在InfluxDB資料庫中,然後通過Grafana來展示監控數據。其中,InfluxDB服務端部署的版本號是1.3.1,Grafana部署的版本號是4.0.1。下麵將結合這3個工具來介紹如何實現對應用的監控。        Metrics.NET移植自Java的metrics,它是一個給CLR提供度量的工具包。在業務代碼中埋點Metrics.NET代碼後,就可以方便地對各技術指標、業務指標進行度量,如:共花多長時間完成某方法的執行、某方法在被執行的過程中共出現過幾次異常、某時間段內共下多少訂單量Metrics.NET共提供5種度量類型:Gauge、Counter、Meter、Histogram以及Timer。其中Meter和Histogram這兩種度量類型目前可以完全滿足筆者所在公司的度量需求,所以,下麵只介紹了Meter和Histogram這兩種,另外3個若有興趣可自行抽空去瞭解。

二、埋點Metrics.NET的方法

首先為需要收集Metrics.NET監控數據的業務項目引用Metrics.dll。 然後,在項目中的App.config/Web.config文件中加上如下配置信息:
1 <add key="AppID" value="150106"/>   
2 <add key="Metrics.DBUri" value="http://139.198.13.12:4126/write"/>
3 <add key="Metrics.UserName" value="Arch"/>
4 <add key="Metrics.Password" value="Arch"/>
5 <add key="Metrics.Database" value="ArchDB"/> 

1、Meter

Meter用於度量TPS(每秒處理的請求數)。 示例:模擬統計成功下單量、下單金額、失敗下單量。 調用Meter對象的Mark()方法: 
 1 static void CreateOrder() 
 2 {        
 3   try        
 4   {                
 5     // 省略關於下單的業務邏輯代碼       
 6     //...... 
 7                    
 8     // 分別統計成功下單量和下單金額,統一寫到MetrisKey中               
 9     MetricsKey.OrderCount.Mark();
10     if (n % 2 == 1)
11     {
12         MetricsKey.OrderMoneyCount.Mark("BuyerA", n);
13     }
14     else
15     {
16         MetricsKey.OrderMoneyCount.Mark("BuyerB", n);
17     }          
18   }         
19   catch (Exception)         
20   {                 
21     // 統計失敗下單量,統一寫到MetrisKey中            
22     MetricsKey.OrderErrorCount.Mark();
23                    
24     // 省略異常處理代碼......         
25   } 
26 }

2Histogram

 

Histogram用於度量流數據中Value的分佈情況,它不僅使您能像Meter一樣測量出TPS ,還能測量出最小值、最大值和平均值。使用場景如:統計伺服器的延遲時間、統計某方法共執行多長時間。 示例:模擬統計航班查詢引擎方法的耗時情況。 調用Histogram對象的Update()方法: 
 1 private readonly Histogram searchFlightTime = MetricsHelper.Histogram("MetricsDemo.SearchFlightTime", Unit.Custom("ms"));
 2 
 3 static void SearchFlight()
 4 {           
 5   Stopwatch stopwatch = Stopwatch.StartNew();  
 6              
 7   // 模擬關於航班查詢的業務邏輯的代碼            
 8   Random random = new Random((int)DateTime.Now.Ticks & 0x0000FFFF); 
 9   var n = Random.Next(100);                 
10   Thread.Sleep(n);                 
11 
12   stopwatch.Stop();        
13 
14   // 統計航班搜索耗時  
15   searchFlightTime.Update(stopwatch.ElapsedMilliseconds);
16 }

三、Grafana配置

查閱Metrics Dashboard Demo的地址:http://139.198.13.12:4127/。打開這個Metrics地址後,如果頁面顯示已登錄狀態,那麼在開始查閱前,請先確認是否把組織切換到了Default Org.:

1、儀錶盤設置

點擊位於下圖上方的Home圖標,會下拉彈出Dashboard列表:   點擊位於上圖下方的Create New按鈕,會進入到新建面板Panel頁面,點擊位於下圖上方的保存圖標按鈕:   在彈出的Save As...對話框中輸入Dashboard名稱,如Arch.OrderCountDemo,然後點擊Save按鈕進行保存:

2、面板(Panel)設置

點擊上面創建的【Arch.OrderCountDemo】Dashboard圖標,進入屬於這個Dashboard的面板(Panel)頁面:   點擊位於上圖的ADD ROW按鈕,進入下圖。其中,Graph表示以圖表(有折線圖、柱狀圖、散點圖、梯形圖)形式展示數據、Singlestat表示單個統計、Table表示以表格形式展示數據、PieChart表示以餅狀圖形式展示數據。這幾種統計類型的面板設置方式類似,本文將以Graph為例進行說明。

2.1、數據設置

點擊上圖的Graph圖標創建圖表: 點擊上圖的Panel Title,在彈出菜單中單擊Edit打開Panel編輯界面,即進入Metrics選項卡面板。 關於Meter的查詢數據語句配置一般如下:   關於Histogram的查詢數據語句配置一般如下: 其中,fill()一般被設為null,但當查詢時間範圍很大時(如1天),請用fill(0);另外,$appId、$serverIP、$summarize這3個變數是在模板(Templating)中設置,請看第3小節的介紹。

2.2、樣式配置

2.2.1、General選項卡用來設置Panel樣式

主要用來設置Panel的標題:

2.2.2、Axes選項卡用來設置坐標軸

Label表示設置左側Y軸旁顯示什麼說明文字,另外,Unit表示設置左側Y軸數字的單位:

2.2.3、Legend選項卡用來設置顯示樣式

2.2.4 Display選項卡用來設置圖表樣式

Draw options子選項卡用來設置圖表顯示效果: Draw Modes:Points表示設置是否在圖中顯示散點; Mode Options:Fill表示設置填充度、Line Width表示設置圖表線的粗細、Point Radius表示設置圓點半徑的長度; Stacking & Null value:Null value選擇null as zero時表示設置當該時間節點在InfluxDB中沒有記錄時,用0替代。

3、模板(Templating)設置

打開Templating設置頁面:   新建變數:   新建serverIP變數: (在Query文本框處,輸的是:SHOW TAG VALUES WITH KEY = "ServerIP")   新建summarize變數其中Values值可以自行添加或刪除,值與值之間用英文狀態的逗號隔開   新建adhoc變數:

4、設置Time Range

一個Dashboard中,除了需要顯示實時監控數據外,有時還需要顯示歷史的監控數據,主要目的是要通過對歷史監控數據的觀察來預測未來的業務量走勢,那麼需要重寫Time Range,即需要在Time range選項卡中進行設置。 例如,在一個Panel中需要顯示近24小時的歷史監控數據,那麼請在這個Panel中加上如下配置:

5、告警設置

在Grafana當前版本(4.0.1)中,告警目前僅支持Graph類型的面板,在將來版本會添加Singlestat和Table類型面板的支持。另外,由於告警查詢語句不支持template變數,所以最好是對不使用template變數的Panel才設置告警。

5.1、設置通知規則

在左側菜單中選擇Alerting -> Notifications進入通知列表頁:   點擊New Notification按鈕新建一個通知: 在Name文本輸入框中,輸入通知名稱,類型Type選擇email。設置完成之後單擊Save按鈕,然後點擊Send Test按鈕測試下通知是否能夠發送成功。

5.2、設置告警規則

進入需要添加告警的Panel的編輯界面,轉到Alert選項卡,點擊Create Alert按鈕,進入Alert Config子選項卡界面進行配置,其中Evaluate every表示設置執行頻率,Conditions表示配置何時告警的條件(WHEN是選擇聚合函數的地方,OF用來設置時間段,IS ABOVE或者IS BELOW用來設置閾值)。 對Alert Config子選項卡界面的配置參考如下:   然後在Notifications子選項卡界面中配置通知規則:

5.3、暫停告警操作

在左側菜單中點擊Alerting -> Alert List進入告警規則列表頁,點擊暫停圖標按鈕就可以停止該告警:

四、其它說明  

1、Grafana匿名訪問地址: http://139.198.13.12:4127/。建議使用Google Chrome瀏覽器打開Grafana; 2、一個MetricsName對應一張數據表,建議明確定義MetricsName; 3、提供的Metrics.dll基於0.4.8的版本增加了Unit Count的返回,且適用於.NET Framework 4.5及其以上版本。

五、總結Metrics的價值  

1、可以實時監控線上程式運行情況,形成閉環、不斷改進; 2、可以預測程式未來大致走向; 3、可以及時發現故障,消滅在用戶反饋之前; 4、Metrics.NET出現異常不影響業務流程; 5、可設置自動報警,即時發送郵件、簡訊、微信(通過API)。

六、Demo下載及更多資料


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • HTML:是Hyper Text Markup Language(超級文本標記語言)的縮寫,HTML不是一種程式,只是一種控制網頁中數據顯示的標識語言。 HTML由一組標簽組成。 HTML的基本結構 <html> <head> <title>第一個HTML示例</title> </head> <bo ...
  • HTML是Web統一語言,這些容納在尖括弧里的簡單標簽,構成瞭如今的Web。 1991年,Tim Berners-Lee編寫了一份叫做“HTML標簽”的文檔,裡面包含了大約20個用來標記網頁的HTML標簽。他直接借用SGML的標記格式,也就是後來我們看到的HTML標記的格式。 從IETF到W3C:H ...
  • 1. ps 鏈接: https://pan.baidu.com/s/1mjYbcJA 密碼: pqdt2. HTML5+CSS3從入門到精通.iso 鏈接: https://pan.baidu.com/s/1cUHz3o 密碼: gdyw3. Javascript視頻教程 鏈接: https://p ...
  • 一切皆對象 屬性:升高 體重 方法:唱歌 跳舞 打招呼 數據類型:字元串、數字、布爾、數組、對象、Null、Undefined (面試會考) Null:空 false Undefined 沒有聲明 false 面向對象 鍵值對 數據類型:字元串 數組 布爾 對象 NAN undefined 知識點1 ...
  • @{ Layout = null; ViewBag.Title = "Login Page"; } IndexMain @*樣式*@ ...
  • 偽元素選擇器: ::first-letter:為某個元素中的文字的首字母或第一個字使用樣式。 ::first-line:為某個元素的第一行文字使用樣式。 ::before:在某個元素之前插入一些內容。 ::after:在某個元素之後插入一些內容 ::selection:匹配元素中被用戶選中或處於高亮 ...
  • 一、指令定義 對於指令,可以把它簡單的理解成在特定DOM元素上運行的函數,指令可以擴展這個元素的功能。 首先來看個完整的參數示例再來詳細的介紹各個參數的作用及用法: 二、指令參數的作用和意義(這個地方只選常用的幾種來講一下) restrict[string] 一般考慮到瀏覽器的相容性,強烈建議使用默 ...
  • /// <summary> /// 抽象聚合介面 /// </summary> public interface IListCollection { Iterator GetIterator(); } //迭代器抽象類 public interface Iterator { bool MoveNex ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...