surging如何使用swagger 組件測試業務模塊

来源:https://www.cnblogs.com/fanliang11/archive/2018/10/07/9751908.html
-Advertisement-
Play Games

1、前言 微服務架構概念的提出已經有非常長一段時間了,但在近期幾年卻開始頻繁地出現,大家都著手升級成微服務架構,使用著各種技術,大家認為框架有服務治理就是微服務,實現單一協議的服務調用,微服務雖然沒有太明確的定義,但是我認為服務應該是一個或者一組相對較小且獨立的功能單元,可以自由組合拆分,針對於業務 ...


1、前言

   微服務架構概念的提出已經有非常長一段時間了,但在近期幾年卻開始頻繁地出現,大家都著手升級成微服務架構,使用著各種技術,大家認為框架有服務治理就是微服務,實現單一協議的服務調用,微服務雖然沒有太明確的定義,但是我認為服務應該是一個或者一組相對較小且獨立的功能單元,可以自由組合拆分,針對於業務模塊的 CRUD 可以註冊為服務,而每個服務都是高度自治的,從開發,部署都是獨立,而每個服務只做單一功能,利用領域驅動設計去更好的拆分成粒度更小的模塊,而框架本身提供了多種協議,如ws,tcp,http,mqtt,rtp,rtcp, 並且有各種功能的中間件,所開發的業務模塊,通過框架可以適用於各種業務場景,讓開發人員專註於業務開發這才是真正意義上的微服務。

 以上只是談下微服務,避免一些人走向誤區。而這篇文章主要介紹下surging如何使用swagger 組件測試業務模塊

surging源碼下載

2、如何使用swagger

 

surging 集成了Kestrel組件並且擴展swagger組件,以下介紹下如何使用swagger組件

xml文檔文件設置

針對於 swagger 需要生成 schema,那麼需要載入介面模塊的xml文檔文件,可以通過項目-屬性-生成-xml文檔文件 進行設置,如下圖所示

通過以上設置,如果掃描載入業務模塊,可以使用dotnet publish -c release 生成模塊文件,如下圖所示

 

文件配置

使用swagger ,如果使用官方提供的surging 引擎的話,就需要開啟Kestrel組件,如以下配置所示

  "Surging": {
    "Ip": "${Surging_Server_IP}|127.0.0.1",
    "WatchInterval": 30,
    "Port": "${Surging_Server_Port}|98",
    "MappingIp": "${Mapping_ip}",
    "MappingPort": "${Mapping_Port}",
    "Token": "true",
    "MaxConcurrentRequests": 20,
    "ExecutionTimeoutInMilliseconds": 30000,
    "Protocol": "${Protocol}|None", //Http、Tcp、None
    "RootPath": "${RootPath}|D:\\userapp",
    "Ports": {
      "HttpPort": "${HttpPort}|280",
      "WSPort": "${WSPort}|96"
    },
    "RequestCacheEnabled": false,
    "Packages": [
      {
        "TypeName": "EnginePartModule",
        "Using": "${UseEngineParts}|DotNettyModule;NLogModule;MessagePackModule;ConsulModule;KestrelHttpModule;WSProtocolModule;EventBusRabbitMQModule;CachingModule;"
      }
    ]
  }

以下是配置swagger,如果不添加以下配置,可以禁用swagger

  "Swagger": {
    "Version": "${SwaggerVersion}|V1", // "127.0.0.1:8500",
    "Title": "${SwaggerTitle}|Surging Demo",
    "Description": "${SwaggerDes}|surging demo",
    "Contact": {
      "Name": "API Support",
      "Url": "https://github.com/dotnetcore/surging",
      "Email": "[email protected]"
    },
    "License": {
      "Name": "MIT",
      "Url": "https://github.com/dotnetcore/surging/blob/master/LICENSE"
    }
  }

 

 通過以上設置,就可以通過http://127.0.0.1:280/swagger進行訪問,效果如下圖所示

測試上傳文件

測試下載文件

 Post 測試

GET 測試

 

五、總結

通過swagger 引擎組件能夠生成業務介面文檔,能夠更好的和團隊進行協作,而surging計劃是去網關中心化,會擴展'關卡(stage)'引擎組件以代替網關,同時也會擴展更多的通信協議,也歡迎大家擴展引擎組件,讓生態更強大。

 


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

-Advertisement-
Play Games
更多相關文章
  • Fs = 1000; % 採樣頻率 N = 1024; % 採樣點數 ,即實際中一次FFT變換所使用的點數n = 0:N-1; % 採樣序列,為plot繪圖用的序列,其對應點表示的真實頻率為 f = f = n*(Fs/N),Fs/N,是頻率解析度,其中0 <= N < max(N)/2-1 f = ...
  • 考慮到以後可能會在深圳工作,所以寫了這個爬蟲,希望對自己的找房過程提供一些便捷。 信息來源是豆瓣的深圳租房小組(想爬取其他城市只需要更換一下URL就好)。 你們一定會說這麼麻煩乾什麼,租房APP不是直接看麽?我也是這麼想的。。。但是租房APP上中介比較多,豆瓣上多是個人房源,中介少,比較可靠。但豆瓣 ...
  • 弄清楚類與對象的本質與基本特征,是進一步學習面向對象編程語言的基本要求。面向對象程式設計與面向過程程式設計在思維上存在著很大差別,改變一種思維方式並不是一件容易的事情。 ...
  • (對於模型中隱藏 $hidden 的欄位,需要使用 makeVisible() 方法來暫時停止 hidden, 放置寫入資料庫時出錯) ...
  • 專業定製新聞網站,仿東方頭條,今日頭條,搜狐自媒體網站源碼開發,支持二級功能變數名稱顯示,新聞資訊聚合的頭條新聞資訊,內容包括今日頭條、頭條新聞、社會熱點、國內國際快訊、軍事、明星、八卦、娛樂、時尚、體育等各類別的頭條新聞資訊。支持電腦版+手機版+微信版+小程式版+APP版,由10年的技術團隊專業定製,需要 ...
  • 二分查找就是待查找的列表進行分半搜索如下所示二分查找普通實現:def erfen(alist, item): start = 0 end = len(alist) - 1 while start item: end = n - 1 else: start = n + 1 return Falseal... ...
  • 線程棧 stuck:存值類型,和引用類型的引用 先進後出,鏈表形式,連續擺放 CLR(公共語言運行庫(Common Language Runtime))啟動進程,main函數為一個線程入口 進程堆heap:存引用類型 進程中的一塊區域 IL:中間語言 對象的屬性為值類型出現在堆里,方法里的值類型,由 ...
  • 1,安裝Microsoft.AspNetCore.Mvc.Versioning NET Core Mvc中,微軟官方提供了一個可用的Api版本控制庫Microsoft.AspNetCore.Mvc.Versioning。 2,修改Startup類 這裡我們需要在Startup類的ConfigureS ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...