Ocelot 集成Butterfly 實現分散式跟蹤

来源:https://www.cnblogs.com/shanyou/archive/2018/02/05/8413506.html
-Advertisement-
Play Games

微服務,通常都是用複雜的、大規模分散式集群來實現的。微服務構建在不同的軟體模塊上,這些軟體模塊,有可能是由不同的團隊開發、可能使用不同的編程語言來實現、有可能布在了幾千台伺服器,橫跨多個不同的數據中心。因此,就需要一些可以幫助理解系統行為、用於分析性能問題的工具。 API網關Ocelot 作為微服務 ...


微服務,通常都是用複雜的、大規模分散式集群來實現的。微服務構建在不同的軟體模塊上,這些軟體模塊,有可能是由不同的團隊開發、可能使用不同的編程語言來實現、有可能布在了幾千台伺服器,橫跨多個不同的數據中心。因此,就需要一些可以幫助理解系統行為、用於分析性能問題的工具。

API網關Ocelot 作為微服務的一個重要組件,出現在系統邊界上的一個面向API的、串列集中式的強管控服務,這裡的邊界是企業IT系統的邊界,主要起到隔離外部訪問與內部系統的作用。通過API網關對外發佈的通常是OpenAPI,在它的後面有眾多的分散式應用,如微服務、消息收發、分散式資料庫、分散式緩存、分散式對象存儲、跨域調用,這些組件共同構成了繁雜的分散式網路。

當應用A發出某個請求時,其背後可能有數十個甚至更多的服務被調用,可謂是“牽一發而動全身”。 如果將分散式系統比作高速公路網,每個前端的請求就相當於高速上行駛的車輛,而處理請求的應用就是高速上的收費站,在收費站上將車輛通行信息記錄成日誌,包括時間、車牌、站點、公路、價格等,如果將所有收費站上的日誌整合在一起,便可以通過唯一的車牌號確定該車的完整通行記錄;分散式調用系統跟蹤和監控就是類比這種思想,對每一次請求進行跟蹤,進而明確每個請求所經過的應用、耗時等信息。

Butterfly被設計為分散式追蹤和APM的Server端,它將包含Collector,Storage,獨立的Web UI,並使用Open Tracing規範來設計追蹤數據。目前僅根據規範實現了Open Tracing API,後續還會相容google的opencensus。這裡順便提下為什麼我們不用zipkin 或是Jaeger,他們只做了tracing,Butterfly比他們多一點就是同時要做metrics和預警,就是要做立體化監控系統。目前Butterfly也是在起步階段,還有非常多的功能需要開發,目前有兩個事情的優先順序比較高一個應用程式進程級別的metrics,一個是後端collector和es的性能優化,歡迎各位同學加入一起開發,我們相信通過不斷的建設,我們.NET社區一樣可以達到Java的高度。回想Ocelot 的發展歷程,2016年才是到現在已經開發了2年時間,完成了3.0版本的開發,現在已經是一個日趨成熟的API網關,通過API網關連接後面的服務,像今天和大家分享的最近我業餘時間在開發的分散式跟蹤的支持,這項任務在一年前提出來,https://github.com/TomPallister/Ocelot/issues/19 這裡有我們的討論,現在集成Butterfly 來實現這個功能,讓我們的微服務能夠可運維。

Butterfly.Client.AspNetCore 為我們提供了在ASP.NET Core項目集成Butterfly的組件,使用很簡單,只需要在ConfigureServices 註冊Butterfly services

public void ConfigureServices(IServiceCollection services)
{
   //your other code 
  services.AddButterfly(option =>
  {
      option.CollectorUrl = "http://localhost:9618";
      option.Service = "my service";
  });
}

其中http://localhost:9618 是Butterfly的服務端,提供了UI,我們在瀏覽器通過http://localhost:9618 就可以訪問到。

那麼在API網關Ocelot 中集成Butterfly 有什麼不一樣呢? 我們在Ocelot項目中加入上述代碼後,我們已經可以在Butterfly UI上看到我們的追蹤數據,只是數據沒有連成一條鏈。那麼我們做集成的工作主要就是以下2點:

一、將追蹤數據串起來,讓我們可以在Butterfly UI上直觀的看到各個節點的數據

二、Ocelot 本身需要加入到系統跟蹤的數據定義

Ocelot 集成Butterfly 實現分散式跟蹤的代碼目前還沒有加入主幹,可以在我的代碼庫的分支https://github.com/geffzhang/Ocelot/tree/Monitoring 下看到,我們首先在Ocelot的路由配置中加入一個配置項,表示是否啟用分散式追蹤:

{
   "ReRoutes": [
     {
       "DownstreamPathTemplate": "/api/values",
       "DownstreamScheme": "http",
       "UpstreamPathTemplate": "/api/values",
       "UpstreamHttpMethod": [ "Get" ],
       "DownstreamHostAndPorts": [
         {
           "Host": "localhost",
           "Port": 5002
         }
       ],
       "HttpHandlerOptions": {
         "AllowAutoRedirect": true,
         "UseCookieContainer": true,
         "UseTracing": true
       }
     },

UseTracing 表示是否啟用分散式追蹤,預設為false,也就是不啟用。 然後在Ocelot.DependencyInjection.IOcelotBuilder 加個介面方法:

image

方法的實現也非常簡單:

image

主要就是加入Ocelot 本身需要加入到系統跟蹤的數據定義,實現上主要使用DiagnosticSource, 官方的文檔:https://github.com/dotnet/corefx/blob/master/src/System.Diagnostics.DiagnosticSource/src/DiagnosticSourceUsersGuide.md 。類似於asp.net core 有個 Diagnostics中間件https://github.com/aspnet/Diagnostics,主要功能是用於報告和處理ASP.NET Core中的異常和錯誤信息,以及診斷Entity Framework核心遷移錯誤。其中還有其他幾項功能,歡迎頁,錯誤代碼頁、如404 頁等。以及一個還算不錯的日誌查看功能,這個功能也是很多人需要的功能,直接線上查看日誌。

image

實現了Butterfly 的介面ITracingDiagnosticListener ,通過DI 註入後Butterfly 會幫我們註冊好。

下麵我們要把我們的分散式追蹤數據串起來,OpenTracing(鏈接:opentracing.io)通過提供平臺無關、廠商無關的API,使得開發人員能夠方便的添加(或更換)追蹤系統的實現。OpenTracing正在為全球的分散式追蹤,提供統一的概念和數據標準。標準的中文版是我們的MVP吳晟翻譯的,同時他也是OpenTracing的主要成員 : https://wu-sheng.gitbooks.io/opentracing-io/content/

在廣義上,一個trace代表了一個事務或者流程在(分散式)系統中的執行過程。在OpenTracing標準中,trace是多個span組成的一個有向無環圖(DAG),每一個span代表trace中被命名並計時的連續性的執行片段。

分散式追蹤中的每個組件都包含自己的一個或者多個span。例如,在一個常規的RPC調用過程中,OpenTracing推薦在RPC的客戶端和服務端,至少各有一個span,用於記錄RPC調用的客戶端和服務端信息。

一個父級的span會顯示的並行或者串列啟動多個子span。在OpenTracing標準中,甚至允許一個子span有個多父span(例如:並行寫入的緩存,可能通過一次刷新操作寫入動作)。

所以集成的關鍵點就在tracerId和spanId的關聯關係的Id 處理上。

tracerid 代表是全局的id,類似於Ocelot的RequestId http://ocelot.readthedocs.io/en/latest/features/requestid.html,存放在http header 里,它的key是ot-traceid,所以在Ocelot裡面可以把全局的RequestId設置為ot-traceid 。

image

同時還需要處理spanid,使得下游的的組件的spanid是它上一級的spanid,也是存放在http header 里,它的key是ot-spanId,我們在OcelotRequestTracer 以及OcelotHttpTracingHandler 需要處理spanid

image

上面我們說完了代碼集成工作,我們來看看效果吧,我搭了一個Demo環境,服務前端—>Ocelot –>服務後端。Butterfly為每個請求生成全局唯一的ID(Traceld),通過它將不同系統的“孤立的”調用信息關聯在一起,還原出更多有價值的數據。

image

上圖是一條API調用請求的調用鏈,在Span列可以看到請求中間過程所經過的一系列應用組件,可以看到最先經過請求端的HttpClient組件,後續調用Ocelot、HttpClient、backend等,形成調用樹(樹上的縮進表示嵌套關係),從調用樹上很容易看到前端請求的完整處理過程。在上圖所示的頁面中也清晰地展示了每塊應用處理請求得具體耗時,非常直觀地進行定位;此外,點擊具體的組件,可以看到這個組件中的日誌記錄

image

對於分散式調用跟蹤系統而言,它並不僅僅提供了調用鏈這一功能,因為它對所有中間件的調用做埋點,所以中間件上的所有情況都可以監控的到。因此,在形成調用鏈的過程中也會形成一份詳細的調用監控報表,它與其他監控的不同之處在於:該監控報表是帶有上下鑽取功能的報表。因為調用鏈是詳細的底層統計,對上可以形成的報表維度是非常豐富的,在上圖所示的調用報表裡,不僅可以看到服務的情況,還可以下鑽到它所調用服務的情況;另外從監控報表上還可以進行調用鏈的下鑽,查看清晰的調用鏈信息。目前Butterfly這塊功能也是需要繼續開發的功能,歡迎各位同學一起加入開發。

還有鏈路分析,鏈路與調用鏈不同,鏈路是一個統計學的概念,而調用鏈是單體調用的過程。分析鏈路的拓撲形態分析:分析來源、去向,識別不合理來源;

image

上圖是全局調用拓撲圖,可以明顯的看到不同的服務之間存在複雜的調用關係,也可以查看某個服務和其他服務之間的調用關係以及調用的頻次; 通過該拓撲圖,架構師可以清楚地觀察到系統上的調用情況。


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

-Advertisement-
Play Games
更多相關文章
  • 什麼是Session Session 是另一種記錄瀏覽器狀態的機制。不同的是Cookie保存在瀏覽器中,Session保存在伺服器中。用戶使用瀏覽器訪問伺服器的時候,伺服器把用戶的信息以某種的形式記錄在伺服器,這就是Session 如果說Cookie是檢查用戶身上的”通行證“來確認用戶的身份,那麼S ...
  • 寫下這個標題的時候,我是矛盾的。 —————— 2017 01 28~2017 05 24 錢給的少了,計劃跳槽,先實現小目標 這個時間段里, 我一直謀划著跳槽,計劃稅前年薪20w的目標,這個時間段裡面,我一直在學習,作為一個野生程式員,學習很有必要,我認為最重要的是數學和英文,這兩個我缺學不好,一 ...
  • 一、Class類的使用 1.Java的反射機制是在編譯並不確定是哪個類被載入了,而是在程式運行的時候才載入、探知、自審。使用在編譯期並不知道的類。這樣的特點就是反射。 2.面向對象的世界里,萬物皆對象(除靜態的成員,普通數據類型不是對象),類是對象類,是java.lang.Class的實例對象3.怎 ...
  • Python版本:3.5.2 假如我們有一個Student類,併在其中定義了一個score屬性,但是score屬性會被顯露出去,沒辦法檢查參數,導致成績可以隨意更改: ~~~~ stu = Student() stu.score = 9999 ~~~~ 這顯然是不合邏輯的,為了限制score的範圍, ...
  • 一、dir內置函數 二、類 1、定義 類名 大駝峰命名法 2、創建 3、self參數(哪一個對象調用方法,self就是哪一個對象的引用 類似於this) (1)、增加屬性 (2)、 調用屬性 self.訪問對象的屬性 self.調用其他的對象方法 (PS 這種在外部賦值屬性的方法 不建議使用哦) ( ...
  • 登錄失敗信息回顯不會的新的一個頁面,而是顯示在登錄頁面 一種方法是: 登錄頁面表單中每個欄位後添加<span>標簽寫入失敗信息,利用ajax技術 通過改變<span>標簽的display:none屬性添加失敗信息 這裡用的類似的方法: 資料庫準備略, 註意寫好對應的user類供BeanHandler ...
  • package com.swift; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileInputStream; import java.io.FileOutputStream; impo... ...
  • lambda x: x * x,實際上就是 def f(x): retrun x * x 關鍵字lambda表示匿名函數,冒號前的x表示函數參數。 匿名函數只能有一個表達式,不用寫return,返回值就是該表達式的結果。 用匿名函數有個好處,因為函數沒有名字,不必擔心函數名衝突。此外,匿名函數也是一 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...