Nginx gateway集群和動(dòng)態(tài)網(wǎng)關(guān)的實(shí)現(xiàn)思路
網(wǎng)關(guān)是系統(tǒng)的唯一對(duì)外的入口,介于客戶端和服務(wù)器端之間的中間層,處理非業(yè)務(wù)功能,提供路由請(qǐng)求、鑒權(quán)、監(jiān)控、緩存、限流等功能。無(wú)論你查看任何一個(gè)微服務(wù)項(xiàng)目架構(gòu),你都會(huì)發(fā)現(xiàn)在客戶端和服務(wù)器端之間有一個(gè)網(wǎng)關(guān),移動(dòng)端的任何請(qǐng)求都必須經(jīng)過(guò)網(wǎng)關(guān)才能到達(dá)服務(wù)端。
網(wǎng)關(guān)怎么實(shí)現(xiàn)集群:使用nginx實(shí)現(xiàn)。
基于nginx部署gateway集群
1、將網(wǎng)關(guān)項(xiàng)目多個(gè)部署啟動(dòng)
例如:
網(wǎng)關(guān)1 127.0.0.1:81
網(wǎng)關(guān)1 127.0.0.1:82
2、各個(gè)微服務(wù)如何知道是哪個(gè)網(wǎng)關(guān)請(qǐng)求的
在網(wǎng)關(guān)的過(guò)濾器中給請(qǐng)求頭添加可以區(qū)別網(wǎng)關(guān)的信息。
動(dòng)態(tài)Gateway
動(dòng)態(tài)網(wǎng)關(guān):任何配置都實(shí)現(xiàn)不用重啟網(wǎng)關(guān)服務(wù)器都可以及時(shí)刷新。
實(shí)現(xiàn)思路:
1、分布式配置中心,閱讀性差。
2、基于數(shù)據(jù)庫(kù)表結(jié)構(gòu)設(shè)計(jì)。
gateway提供對(duì)應(yīng)的接口:1、直接新增路由;2、直接修改路由
使用api添加gateway 路由,直接注入該bean 調(diào)用 loadRoute1方法就可以添加路由策略了。
@Service public class GatewayService implements ApplicationEventPublisherAware { private ApplicationEventPublisher publisher; @Autowired private RouteDefinitionWriter routeDefinitionWriter; @Override public void setApplicationEventPublisher(ApplicationEventPublisher applicationEventPublisher) { this.publisher = applicationEventPublisher; } public void initAllRoute() { // 從數(shù)據(jù)庫(kù)查詢配置的網(wǎng)關(guān)配置 List<GatewayRouteEntity> gateWayEntities = gatewayRouteMapper.gateWayAll(); for (GatewayRouteEntity gw : gateWayEntities) { loadRoute(gw); } } public String loadRoute1() { RouteDefinition definition = new RouteDefinition(); Map<String, String> predicateParams = new HashMap<>(8); PredicateDefinition predicate = new PredicateDefinition(); FilterDefinition filterDefinition = new FilterDefinition(); Map<String, String> filterParams = new HashMap<>(8); // 如果配置路由type為0的話 則從注冊(cè)中心獲取服務(wù) URI uri = UriComponentsBuilder.fromUriString("lb://kaico-member/").build().toUri(); // 定義的路由唯一的id definition.setId("member"); predicate.setName("Path"); //路由轉(zhuǎn)發(fā)地址 predicateParams.put("pattern", "/member/**"); predicate.setArgs(predicateParams); // 名稱是固定的, 路徑去前綴 filterDefinition.setName("StripPrefix"); filterParams.put("_genkey_0", "1"); filterDefinition.setArgs(filterParams); definition.setPredicates(Arrays.asList(predicate)); definition.setFilters(Arrays.asList(filterDefinition)); definition.setUri(uri); routeDefinitionWriter.save(Mono.just(definition)).subscribe(); this.publisher.publishEvent(new RefreshRoutesEvent(this)); return "success"; } }
使用數(shù)據(jù)庫(kù)實(shí)現(xiàn)動(dòng)態(tài)路由
根據(jù)上面的案例,將配置信息添加到數(shù)據(jù)庫(kù)中(數(shù)據(jù)庫(kù)表的設(shè)計(jì)只要符合只用場(chǎng)景就可以了,沒(méi)有什么特別要求),在調(diào)用相關(guān)的api添加到gateway中即可。
參考學(xué)習(xí)文檔:https://www.cnblogs.com/crazymakercircle/p/11704077.html
官放文檔:https://docs.spring.io/spring-cloud-gateway/docs/3.0.5-SNAPSHOT/reference/html/#gateway-starter
到此這篇關(guān)于Nginx gateway集群和動(dòng)態(tài)網(wǎng)關(guān)的文章就介紹到這了,更多相關(guān)Nginx gateway集群內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Windows安裝nginx1.10.1反向代理訪問(wèn)IIS網(wǎng)站
這篇文章主要為大家詳細(xì)介紹了Windows安裝nginx1.10.1反向代理訪問(wèn)IIS網(wǎng)站的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11nginx全局塊的user指令的實(shí)現(xiàn)示例
user用于配置運(yùn)行Nginx服務(wù)器的worker進(jìn)程的用戶和用戶組,本文主要介紹了nginx全局塊的user指令的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07Nginx+FastDFS搭建圖片服務(wù)器的方法實(shí)現(xiàn)
這篇文章主要介紹了Nginx+FastDFS搭建圖片服務(wù)器的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03Nginx+Keepalived實(shí)現(xiàn)雙機(jī)熱備
這篇文章主要介紹了Nginx+Keepalived實(shí)現(xiàn)雙機(jī)熱備,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06聊聊Django+uwsgi+nginx服務(wù)器部署問(wèn)題
這篇文章主要介紹了Django+uwsgi+nginx服務(wù)器部署的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03nginx中配置使用proxy?protocol協(xié)議的全過(guò)程
proxy protocol是一個(gè)Internet協(xié)議,通過(guò)為tcp添加一個(gè)很小的頭信息,來(lái)方便的傳遞客戶端信息,在網(wǎng)絡(luò)情況復(fù)雜又需要獲取用戶真實(shí)IP時(shí)非常有用,這篇文章主要給大家介紹了關(guān)于nginx中配置使用proxy?protocol協(xié)議的相關(guān)資料,需要的朋友可以參考下2022-04-04針對(duì)OpenSSL安全漏洞調(diào)整Nginx服務(wù)器的方法
這篇文章主要介紹了針對(duì)OpenSSL漏洞調(diào)整Nginx服務(wù)器的方法,2014年爆出的SSL安全漏洞震驚了全世界,需要的朋友可以參考下2015-06-06解決nginx已經(jīng)配置過(guò)跨域不生效問(wèn)題
這篇文章主要介紹了解決nginx已經(jīng)配置過(guò)跨域不生效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12