在微服務框架Demo.MicroServer中添加SkyWalking+SkyApm-dotnet分散式鏈路追蹤系統

来源:https://www.cnblogs.com/peyshine/archive/2020/05/13/12885594.html
-Advertisement-
Play Games

1.APM工具的選取 Apm監測工具很多,這裡選用網上比較火的一款Skywalking。 Skywalking是一個應用性能監控(APM)系統,Skywalking分為服務端Oap、管理界面UI、以及嵌入到程式中的探針Agent部分,大概工作流程就是在程式中添加探針採集各種數據發送給服務端保存,然後 ...


1.APM工具的選取

Apm監測工具很多,這裡選用網上比較火的一款Skywalking。 Skywalking是一個應用性能監控(APM)系統,Skywalking分為服務端Oap、管理界面UI、以及嵌入到程式中的探針Agent部分,大概工作流程就是在程式中添加探針採集各種數據發送給服務端保存,然後在UI界面可以看到收集過來的各種監測數據,來完成它的核心使命:性能監控和分散式調用鏈追蹤能力。下圖是skywalking官方的一個圖,也可以說明這三者之間的關聯關係

2.服務端(OAP)和界面(UI)的安裝

這裡直接在apache地址:http://skywalking.apache.org/downloads/ 下載了一個6.6.0版本的zip文件,由於之前在本地的windows上安裝過,發現安裝包裡面有兩個啟動文件,分別為:startup.bat和startup.sh,分別用於window上啟動和linux啟動,這裡我直接將之前下載好的上傳到linux上來安裝。   上傳後解壓縮,就會得到以下截圖的幾個文件   進入到config配置目錄下麵,有一個名稱叫application.yml的文件   對這個配置文件進行編輯 vim application.yml   我們直接定位到數據存儲部分,也就是節點storage,官方文檔裡面也有說明,為了方便快速入門,配置文件預設採用的是H2存儲,但是推薦使用ElasticSearch存儲,由於之前我安裝過Exceptionless,在這台機器上已經安裝過elasticsearch(如果沒有安裝過可以網上找下,有很多這方面的文章),所以我這裡將H2部分註釋掉,然後將elasticsearch部分放開,並修改紅色方框里的兩個配置文件:
nameSpace: ${SW_NAMESPACE:"exceptionless"}
clusterNodes: ${SW_STORAGE_ES_CLUSTER_NODES:localhost:9300}
需要註意的是:第一個SW_NAMESPACE需要與ElasticSearch配置的cluster_name名稱一致   啟動skywalking會占用四個埠:8080,10800,11800,12800,由於我本機安裝過apollo,8080ui埠已經被占用,所以這裡我必須要先修改UI界面使用的8080埠才能啟動它。 開始修改UI界面使用的8080埠(如果你的8080埠並沒有被占用,可以跳過,不用修改) 回到配置目錄的上一級:cd .. 可以看到一個webapp的文件夾   進入這個目錄:cd webapp/ 然後對webapp.yml文件進行修改   這裡我將原來server界面下麵的port從8080改到8088,然後保存   配置文件修改完了,開始啟動skywalking的服務端和UI界面,啟動腳本放在目錄:apache-skywalking-apm-bin/bin 裡面   上面有說到startup.bat和startup.sh分別用在windows上和linux上啟動,這裡用./startup.sh   啟動命令執行完成之後可以看到OAP和Web兩個項目啟動成功的提示,也就是我們說的服務端和UI界面。 驗證一下,通過配置的ip+8088埠(如果沒有修改則是預設的8080)來訪問一下界面,如圖: 至此,我們準備工作做完了,下麵我們在程式中安裝探針,來採集數據.  

3.安裝探針(Agent)採集數據

由於Skywalking本身是採用java編寫的,所以SkyApm-dotnet這個項目就是專門為 .NET 開發的探針,目前支持 ASP.NET Core 以及 ASP.NET,下麵我們將SkyApm-dotnet無侵入式的集成到.Net Core實現的微服務項目中   第一步:使用下麵的命令來進行 Agent 的安裝,這裡據說需要以管理員身份運行
dotnet tool install -g SkyAPM.DotNet.CLI

 

第二步:添加環境變數,可以直接在launchSettings.json文件中添加以下代碼來設置
"environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development",
        "ASPNETCORE_HOSTINGSTARTUPASSEMBLIES": "SkyAPM.Agent.AspNetCore",
        "SKYWALKING__SERVICENAME": "Demo.MicroServer.UserService"
      }

 

第三步:在程式中安裝NuGet包:SkyAPM.Agent.AspNetCore

 

第四步:在應用程式根目錄下使用以下命令生成skyapm.json的配置文件,[service name]替換為服務的名稱,[server]替換為Skywalking安裝的計器ip

dotnet skyapm config [service name] [server]:11800

執行完成之後可以看到目錄下麵已經生成了一個skyapm.json的文件,將其屬性複製到輸出目錄設置為如果較新則複製,我這裡是用之前發佈在github上的微服務框架中的一個實例來測試的,所有代碼均已上傳,需要的可以通過頁面又上角Github地址獲取代碼

 

4.採集數據並查看

在Swagger中隨便調用幾個介面來測試數據的採集情況,然後到UI界面查看數據,流程順利的話,可以看到數據已經都有採集到

 

基本工作都已經完成,這個裡面還有很多玩法,快動手試試吧。

 


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

-Advertisement-
Play Games
更多相關文章
  • 在python3中對字元串的操作如下 1 info = "you are \t{name} and age is {age}" 2 print(info.capitalize()) #首字母大寫 3 print(info.count("g")) #計算字元串中g的數量 4 print(info.ce ...
  • 列表的操作:增刪改查以及列表的三種拷貝方式 1 names = ["tianjie","yecai","haitao","xinlin"] 2 names.append("tianjie") #列表在尾部新增 3 print(names) 4 print(names[0],names[2]) 5 p ...
  • 字典的增刪改查及遍歷 1 info = { 2 "stu3":"yuanyuan", 3 "stu1":"tianjie", 4 "stu2":"wangxinlin" 5 } 6 print(type(info)) #輸出類型 7 print(info) 8 print(info["stu1"]) ...
  • 什麼是 JWT Json web token (JWT), 是為了在網路應用環境間傳遞聲明而執行的一種基於 JSON 的開放標準((RFC 7519). 定義了一種簡潔的,自包含的方法用於通信雙方之間以 JSON 對象的形式安全的傳遞信息。因為數字簽名的存在,這些信息是可信的,JWT 可以使用 HM ...
  • 簡介 redis 多數據源主要的運用場景是在需要使用多個 redis 伺服器或者使用多個 redis 庫,本文采用的是 fastdep 依賴集成框架,快速集成 Redis 多數據源並集成 lettuce 連接池,只需引入依賴後在 yaml 文件中配置多數據源連接信息即可。 源碼地址 希望大家可以 s ...
  • 鏈表實現隊列 創建3個文件:queueLinked.h、queueLinked.c、queueLinkedTest.c queueLinked.h c include include include include "queueLinked.h" // 功能: 列印錯誤信息後就錯誤退出程式. // ...
  • docx模塊報錯 python安裝docx模塊出現Import Error: No module named 'exceptions'的解決方案 註意:docx是python2的模塊,python3的第三方模塊還沒進行更新,所以不好使了,所以,你在python3中安裝docx模塊可以安裝,但是imp ...
  • 前言 市面上消息隊列中間件管理有蠻多的,如:ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,RocketMQ,但我最先接觸的可能就是 Kafka 了,不過那時候為了用,只知道部分實用性的東西,這兩天稍稍花了點時間看了看。 消息隊列 在我看來,消息隊列的出現更多的是解耦合, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...