.NET Core集成SkyWalking+SkyAPM-dotne實現分佈式鏈路追蹤

  • 2020 年 12 月 8 日
  • 筆記

.NET Core集成SkyWalking+SkyAPM-dotnet實現分佈式鏈路追蹤

SkyWalking是一款APM(應用性能管理),其他的還有Cat、Zipkin、Pinpoint等。

隨着微服務架構的流行,一次請求會涉及多個服務的調用,並且服務本身也可能會依賴其他服務,整個請求路徑會構成一個調用鏈,當某個節點發生異常時,整個調用鏈的穩定性都會受到影響,SkyWalking可以幫助理解系統行為和分析性能問題。SkyWalking包括了分佈式追蹤、性能指標分析、應用和服務依賴分析等。
雖然目前市面許多APM系統,但目前.NET上只有SkyWalking可用,通過使用SkyAPM-dotnet,感覺大佬們無私的奉獻。

一,SkyWalking安裝

打開鏈接//archive.apache.org/dist/skywalking,由於目前SkyAPM-dotnet最大僅支持7.0.0,因此最多僅能選擇這個版本。

選擇此包進行下載,由於7.0.0版本目前還無鏡像,下載較慢,可以通過百度網盤的離線下載功能進行下載,速度會快一點。默認佔用8080, 10800, 11800, 12800端口。

下載完成後,解壓,windows下,打開apache-skywalking-apm-bin\bin\startup.bat,會彈出兩個框:

 瀏覽器打開//localhost:8080/,出現SkyWalking管理界面既視為啟動成功,關閉上面兩框則會關閉SkyWalking服務。

二,.NET Core項目集成SkyAPM-dotnet

新建一個web項目,安裝nuget包SkyAPM.Agent.AspNetCore

在我寫博客的這會,剛剛更新了1.1.0版本,我用.NET Core 3.1試了1.1.0和1.0.0版本,雖然沒有報錯,但一直沒捕捉到鏈接請求,最後用了0.9.0,有興趣的博友們可以自己慢慢嘗試。

新建配置文件skyapm.json,修改實際的ip地址

 1 {
 2   "SkyWalking": {
 3     "ServiceName": "asp-net-core-aspnetcore",
 4     "Namespace": "",
 5     "HeaderVersions": [
 6       "sw6"
 7     ],
 8     "Sampling": {
 9       "SamplePer3Secs": -1,
10       "Percentage": -1.0
11     },
12     "Logging": {
13       "Level": "Information",
14       "FilePath": "logs/skyapm-{Date}.log"
15     },
16     "Transport": {
17       "Interval": 3000,
18       "ProtocolVersion": "v6",
19       "QueueSize": 30000,
20       "BatchSize": 3000,
21       "gRPC": {
22         "Servers": "192.168.1.148:11800",
23         "Timeout": 10000,
24         "ConnectTimeout": 10000,
25         "ReportTimeout": 600000
26       }
27     }
28   }
29 }

新增環境變量 ASPNETCORE_HOSTINGSTARTUPASSEMBLIES“:SkyAPM.Agent.AspNetCore 

可修改launchSettings.json文件

 也可在Program.cs中配置

 Environment.SetEnvironmentVariable("ASPNETCORE_HOSTINGSTARTUPASSEMBLIES", "SkyAPM.Agent.AspNetCore");

到此,配置完成,啟動項目。

瀏覽器訪問//localhost:8080/,打開追蹤Tab,時間範圍那有點bug,需要調整下結束時間,不然數據出不來。

 

詳細的各位博友慢慢研究。附上SkyApm-dotnet示例代碼://github.com/SkyAPM/SkyAPM-dotnet/tree/master/sample