Ocelot入門實踐

来源:https://www.cnblogs.com/maxne/archive/2019/03/16/10542031.html
-Advertisement-
Play Games

博主是第一次寫技術文檔,一是對這兩年工作以來的一些技術和經驗進行整理,二也是希望能和大家多多分享交流,如有寫的不對的地方望大家多多指正。進入正題 Ocelot 概念就不說了,大家自行百度,今天做一個Ocelot實例 1.VS新建空白解決方案 2.右鍵解決方案新建項目Service1,Service2 ...


博主是第一次寫技術文檔,一是對這兩年工作以來的一些技術和經驗進行整理,二也是希望能和大家多多分享交流,如有寫的不對的地方望大家多多指正。進入正題


 

Ocelot 概念就不說了,大家自行百度,今天做一個Ocelot實例

 

1.VS新建空白解決方案

 

2.右鍵解決方案新建項目Service1,Service2選擇Api項目模板

 

右鍵解決方案添加項目Gateway選擇空項目模板

 

建立完成後解決方案如下

3.右鍵解決方案=>設置啟動項目

 

打開Service1 launchSettings.json文件,修改"applicationUrl": "http://localhost:7001" ,"launchBrowser": false,

打開Service2 launchSettings.json文件,修改"applicationUrl": "http://localhost:7002" ,"launchBrowser": false,

打開Gateway launchSettings.json文件,修改"applicationUrl": "http://localhost:7000" ,"launchBrowser": false,

 

 4.打開Service1 中 ValuesController改為如下:

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Threading.Tasks;
 5 using Microsoft.AspNetCore.Mvc;
 6 
 7 namespace Service1.Controllers
 8 {
 9     [Route("api/[controller]")]
10     [ApiController]
11     public class ValuesController : ControllerBase
12     {
13         // GET api/values
14         [HttpGet]
15         public ActionResult<string> Get()
16         {
17             return "這是 Service1 ";
18         }
19 
20     }
21 }

 

 

 打開Service2 中 ValuesController改為如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;

namespace Service2.Controllers
{
    [Route("api/[controller]")]
    [ApiController]
    public class ValuesController : ControllerBase
    {
        // GET api/values
        [HttpGet]
        public ActionResult<string> Get()
        {
            return "這是 Service2 ";
        }
    }
}

 

5. VS =>調試=>開始執行

打開postman api測試工具 請求 http://localhost:7001/api/values

 

 

請求 http://localhost:7002/api/values

 

 

service準備完畢,接下來接入Ocelot

6.Gateway項目安裝nuget包 Install-Package Ocelot

 

Gateway項目下添加ocelot.json文件,右鍵屬性,如果較新則複製,併進行如下配置 

{
  "ReRoutes": [
    {
      //Upstream表示上游請求,即客戶端請求到API Gateway的請求
      "UpstreamPathTemplate": "/Service1/{url}", //請求路徑模板
      "UpstreamHttpMethod": [ "Get", "Post" ], //請求方法數組

      "UseServiceDiscovery": false, //啟用服務發現

      //Downstream表示下游請求,即API Gateway轉發的目標服務地址
      "DownstreamPathTemplate": "/api/{url}", //下游請求地址模板
      "DownstreamScheme": "http", //請求協議,目前應該是支持http和https
      "DownstreamHostAndPorts": [ //請求服務地址
        {
          "Host": "localhost",
          "Port": 7001
        }
      ]
    },
    {
      "UpstreamPathTemplate": "/Service2/{url}",
      "UpstreamHttpMethod": [ "Get", "Post" ],

      "UseServiceDiscovery": false,

      "DownstreamPathTemplate": "/api/{url}",
      "DownstreamScheme": "http",
      "DownstreamHostAndPorts": [
        {
          "Host": "localhost",
          "Port": 7002
        }
      ]
    }
  ],
  "GlobalConfiguration": {
    //"ServiceDiscoveryProvider": {
    //  "Host": "127.0.0.1",
    //  "Port": 8500,
    //  "Type": "PollConsul"
    //}
  }
}

 打開Program.cs,修改如下:

public class Program
    {
        public static void Main(string[] args)
        {
            CreateWebHostBuilder(args).Build().Run();
        }

        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
            .ConfigureAppConfiguration((hostingContext, builder) =>
            {
                builder.SetBasePath(hostingContext.HostingEnvironment.ContentRootPath)
                .AddJsonFile("ocelot.json", false, true);
            })
            .UseStartup<Startup>();
    }

打開Startup.cs文件,進行如下配置:

public void ConfigureServices(IServiceCollection services)
        {
            services.AddOcelot();//添加Ocelot服務
        }
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseOcelot().Wait();//使用Ocelot服務
        }

Ocelot配置完畢,VS=>調試=>開始執行

打開postman工具進行測試

 

請求 http://localhost:7000/Service1/values

 

請求 http://localhost:7000/Service2/values

 

OK!打完收工


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

-Advertisement-
Play Games
更多相關文章
  • 1 #include 2 #include 3 #include 4 5 #define SIZE 5 //數組中元素的數量 6 7 void swap(int *p1, int *p2) //交換數組中的兩個元素 8 { 9 int temp = *p1; //創建變數儲存元素p1的指針 10 *... ...
  • 2019年3月16日對於合肥.NET來說是一個特別的日子,因為這是合肥.NET技術社區首次非正式線下聚會!這次聚會受場地限制(畢竟是聚餐的形式),即使換成了小椅子後,最多也只能容納24個人,所以還有一些小伙伴不能到現場參加,這裡對他們說聲抱歉,讓我們期待下次的聚會吧,下次我們將主要以主題演講為主,這 ...
  • 使用 HttpRequester 更方便的發起 HTTP 請求 Intro 一直感覺 .net 裡面(這裡主要說的是 .net framework 下)發送 HTTP 請求的方式用著不是特別好用,而且在 .net framework 里發送 HTTP 請求的方式有好幾種,如: /`WebReques ...
  • 1、現有一個字元串集合,集合中存的是數字,把大於等於2的數值,列印出來,需要用到擴展方法、泛型、委托 class Projram{ static void Main(String[] args){ //定義一個集合, List<string> list = new List<string>{"1", ...
  • 本篇介紹如何在Net Core 環境下部署時,將相同的第三方依賴dll給指定到一個共用的目錄中,網上木有相關教程,只能自己研究好了,給大伙第一個分享了。 ...
  • 寫在前面 C#5.0中,對非同步編程進行了一次革命性的重構,引入了async和await這兩個關鍵字,使得開發人員在不需要深刻瞭解非同步編程的底層原理,就可以寫出十分優美而又代碼量極少的代碼。如果使用得當,你可以寫出具有並行化並且性能較高的程式,但是同時也增加了對非同步編程理解的複雜度,畢竟在C#5.0里 ...
  • 序列化介紹: 把對象用一種新的格式來表示。 系列化只序列化數據。 序列化不建議使用自動屬性 為什麼要序列化: 將一個複雜的對象轉換流,方便存儲與信息交換。 二進位序列化: 就是將對象變成流的過程,把對象變成byte[ ]。 反序列化: 練習:添加對象到array list中,進行序列化和反序列化。 ...
  • 在項目開始之前我們可以先去瞭解一下IConfiguration介面,.Net Core Web應用程式類似於一個控制台,當程式運行到Startup時會自動註入IConfiguration,預設讀取當前.Net Core Web應用程式中的appsettings.json文件。讀取當前.Net Cor ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...