在微服務框架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
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...