欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ASP.NET?Core中的Ocelot網(wǎng)關(guān)介紹

 更新時(shí)間:2022年04月08日 10:57:30   作者:暗斷腸  
這篇文章介紹了ASP.NET?Core中的Ocelot網(wǎng)關(guān),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1.簡介

Ocelot原本設(shè)計(jì)僅為與.NET Core一起使用的,它是一個(gè).NET API網(wǎng)關(guān),作為面向使用.NET運(yùn)行微型服務(wù)/面向服務(wù)的體系結(jié)構(gòu)需要統(tǒng)一的系統(tǒng)入口點(diǎn),即當(dāng)客戶端(Web站點(diǎn),手機(jī)APP)等訪問Web API的時(shí)候,Ocelot作為統(tǒng)一的入口點(diǎn)會(huì)根據(jù)請求地址分發(fā)到對應(yīng)的API站點(diǎn)去(尋址)。而Ocelot還集成很多功能,例路由,認(rèn)證,授權(quán),限速等等功能點(diǎn),Ocelot官網(wǎng)還建議認(rèn)證這塊最好跟身份驗(yàn)證(IdentityServer4)一起使用,承載令牌輕松集成。具體詳情大家可以去官網(wǎng)(https://ocelot.readthedocs.io/en/latest/introduction/bigpicture.html)了解下。

而查看Ocelot源碼,我們會(huì)看到Ocelot是按特定順序排列的一堆中間件(Middleware)組成的管道。

Ocelot將HttpRequest對象操作到由其配置指定的狀態(tài),直到到達(dá)請求構(gòu)建器中間件,在中間件中它創(chuàng)建一個(gè)HttpRequestMessage對象,該對象用于向下游服務(wù)發(fā)出請求。發(fā)出請求的中間件是Ocelot管道中的最后一件事。它不會(huì)調(diào)用下一個(gè)中間件。來自下游服務(wù)的響應(yīng)存儲(chǔ)在每個(gè)請求范圍的存儲(chǔ)庫中,并在請求返回Ocelot管道時(shí)進(jìn)行檢索。有一塊中間件將HttpResponseMessage映射到HttpResponse對象,然后將其返回給客戶端。

2.Ocelot配置

根據(jù)官網(wǎng)介紹,Ocelot有五種配置:

2.1基礎(chǔ)集成(Basic Implementation)

當(dāng)客戶端訪問下游服務(wù)站點(diǎn)時(shí)候,會(huì)統(tǒng)一經(jīng)過Ocelot網(wǎng)關(guān),Ocelot網(wǎng)關(guān)Host主機(jī)首先會(huì)讀取configuration.json配置信息,根據(jù)配置文件去尋找對應(yīng)下游服務(wù)站點(diǎn)并返回處理結(jié)果給客戶端。這一個(gè)過程可以稱為路由尋址。

2.2集成IdentityServer(With IdentityServer)

當(dāng)服務(wù)站點(diǎn)涉及認(rèn)證跟授權(quán)的時(shí)候,可以通過在Ocelot網(wǎng)關(guān)上集成IdentityServer,當(dāng)客戶端訪問下游服務(wù)站點(diǎn)時(shí)候,會(huì)先通過IdentityServer認(rèn)證跟授權(quán)后才分發(fā)到下游服務(wù)站點(diǎn)。

2.3多個(gè)網(wǎng)關(guān)實(shí)例集群(Multiple Instances)

單個(gè)Ocelot網(wǎng)關(guān)是比較危險(xiǎn)的,如果這個(gè)網(wǎng)關(guān)掛掉了,所有下游服務(wù)站點(diǎn)都將無法訪問,這樣子是無法做到高可用的。要解決這個(gè)問題,可以部署多臺(tái)Ocelot網(wǎng)關(guān)集群,而Ocelot也集成了負(fù)載均衡器。

2.4集成Consul服務(wù)發(fā)現(xiàn)(With Consul)

查看官網(wǎng)文檔負(fù)載均衡這一欄目,我們知道Ocelot已經(jīng)支持簡單的負(fù)載功能,當(dāng)下游站點(diǎn)存在多個(gè)服務(wù)結(jié)點(diǎn)的時(shí)候,Ocelot能夠承擔(dān)起負(fù)載均衡的作用。但是它不提供健康檢查,服務(wù)的注冊也只能通過手動(dòng)在配置文件里面添加完成。這不夠靈活并且在一定程度下會(huì)有風(fēng)險(xiǎn)。這個(gè)時(shí)候我們就可以用Consul來做服務(wù)發(fā)現(xiàn),它能與Ocelot完美結(jié)合。

2.5集成Service Fabric(With Service Fabric)

如果您在Service Fabric中部署了服務(wù),則通常將使用命名服務(wù)來訪問它們。

3.總結(jié)

Ocelot網(wǎng)關(guān)是系統(tǒng)給外部唯一訪問入口,就好比公司的門衛(wèi)承擔(dān)著尋址、出入限制、安全檢查、位置引導(dǎo)等等功能。它還提供了路由,身份驗(yàn)證、監(jiān)控、負(fù)載均衡、緩存、請求分片與管理、靜態(tài)響應(yīng)處理等等功能。Ocelot網(wǎng)關(guān)的核心要點(diǎn)是,所有的客戶端和消費(fèi)端都通過統(tǒng)一的網(wǎng)關(guān)接入微服務(wù),在網(wǎng)關(guān)層處理所有的非業(yè)務(wù)功能。通常網(wǎng)關(guān)也是提供REST/HTTP的訪問API,服務(wù)端通過網(wǎng)關(guān)注冊和管理服務(wù)。該章節(jié)之后,我會(huì)繼續(xù)根據(jù)GitHub貢獻(xiàn)者開源項(xiàng)目上面Ocelot Demo實(shí)例介紹它的功能。

Ocelot Demo地址:https://github.com/catcherwong-archive/APIGatewayDemo。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論