LindDotNetCore~Ocelot實現微服務網關

回到目錄html

網關在硬件裏有本身的定義,而在軟件架構裏也有本身的解釋,它就是全部請求的入口,請求打到網關上,通過處理和加工,再返回給客戶端,這個處理過程當中固然就是網關的核心,也是Ocelot的核心,咱們能夠把用戶受權,校驗,緩存,認證等不少關注點在網關中實現!git

善友大哥收錄的:http://www.csharpkit.com/2018-01-06_69695.htmlgithub

原文地址:http://www.cnblogs.com/axzxs2001/p/8005041.htmljson

Github地址:https://github.com/TomPallister/Ocelotapi

定義

API網關是一個服務器,是系統的惟一入口。從面向對象設計的角度看,它與外觀模式相似。API網關封裝了系統內部架構,爲每一個客戶端提供一個定製的API。它可能還具備其它職責,如身份驗證、監控、負載均衡、緩存、請求分片與管理、靜態響應處理。緩存

例如:手機和WEB網站都須要調用API接口,它們直接與網關進行通信,而不用關心具體的服務是A仍是B服務器

 

 項目Demo

安裝Ocelot包:Install-Package Ocelot架構

創建兩個項目,網關主項目,DemoA和DemoB,這樣A和B兩個項目都會指定網關項目,經過訪問網關就能夠訪問這兩個項目了.app

Gateway網關項目,端口是5000負載均衡

DemoA項目,端口是5001

DemoB項目,端口是5002

在Gateway項目添加配置文件configuration.json,將它複製到輸出目錄,右鍵-屬性-始終複製

{
  "ReRoutes": [
    {
      "DownstreamPathTemplate": "/api/polly",
      "DownstreamScheme": "http",
      "DownstreamPort": 5001,
      "DownstreamHost": "localhost",
      "UpstreamPathTemplate": "/api/polly",
      "UpstreamHttpMethod": [ "Get" ],
      "QoSOptions": {
        "ExceptionsAllowedBeforeBreaking": 3,
        "DurationOfBreak": 10,
        "TimeoutValue": 5000
      },
      "HttpHandlerOptions": {
        "AllowAutoRedirect": false,
        "UseCookieContainer": false
      },
      "AuthenticationOptions": {
        "AuthenticationProviderKey": "",
        "AllowedScopes": []
      }
    }
  ]
}

現時在網關裏配置子服務時,也支持路由規則,如控制器,Action時,若是你但願匹配以某個字符做爲前綴的Restful標準的,能夠經過下面代碼進行配置

   {
      "DownstreamPathTemplate": "/api/{controller}",
      "DownstreamScheme": "http",
      "DownstreamPort": 5001,
      "DownstreamHost": "localhost",
      "UpstreamPathTemplate": "/api/{controller}",
      "UpstreamHttpMethod": [ "Get", "Post", "Put", "Delete" ],
    },

在網關的啓動時,把配置文件注入

        public static IWebHost BuildWebHost(string[] args)
        {
            IWebHostBuilder builder = new WebHostBuilder();

            //注入WebHostBuilder

            return builder.ConfigureServices(service =>
             {
                 service.AddSingleton(builder);
             }).ConfigureAppConfiguration(conbuilder =>
             {
                 conbuilder.AddJsonFile("configuration.json");
             }).UseKestrel()
               .UseUrls("http://*:5000")
               .UseStartup<Startup>()
               .Build();
        }

添加ocelot的中間件和服務

services.AddOcelot(Configuration as ConfigurationRoot);

app.UseOcelot().Wait();

調試多個項目,這時咱們的 5000和5001端口都會被監聽,咱們輸入之間配置的api/polly路徑,而後就能夠看到它會本身綁定到5001這個子站上!

 

這樣,咱們的網關就算是跑起來了,全部項目有本身的路由模版,根據路由來查找服務!全部服務在外面看上去都像一個網站!

回到目錄

相關文章
相關標籤/搜索