回到目錄 網關在硬體里有自己的定義,而在軟體架構里也有自己的解釋,它就是所有請求的入口,請求打到網關上,經過處理和加工,再返回給客戶端,這個處理過程中當然就是網關的核心,也是Ocelot的核心,我們可以把用戶授權,校驗,緩存,認證等很多關註點在網關中實現! 善友大哥收錄的:http://www.cs ...
網關在硬體里有自己的定義,而在軟體架構里也有自己的解釋,它就是所有請求的入口,請求打到網關上,經過處理和加工,再返回給客戶端,這個處理過程中當然就是網關的核心,也是Ocelot的核心,我們可以把用戶授權,校驗,緩存,認證等很多關註點在網關中實現!
善友大哥收錄的:http://www.csharpkit.com/2018-01-06_69695.html
原文地址:http://www.cnblogs.com/axzxs2001/p/8005041.html
Github地址:https://github.com/TomPallister/Ocelot
定義
API網關是一個伺服器,是系統的唯一入口。從面向對象設計的角度看,它與外觀模式類似。API網關封裝了系統內部架構,為每個客戶端提供一個定製的API。它可能還具有其它職責,如身份驗證、監控、負載均衡、緩存、請求分片與管理、靜態響應處理。
例如:手機和WEB網站都需要調用API介面,它們直接與網關進行通訊,而不用關心具體的服務是A還是B
項目Demo
安裝Ocelot包:Install-Package Ocelot
建立兩個項目,網關主項目,DemoA和DemoB,這樣A和B兩個項目都會指定網關項目,通過訪問網關就可以訪問這兩個項目了.
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": [] } } ] }
在網關的啟動時,把配置文件註入
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這個子站上!
這樣,我們的網關就算是跑起來了,所有項目有自己的路由模版,根據路由來查找服務!所有服務在外面看上去都像一個網站!