目錄
- 基于nginx部署gateway集群
- 動態Gateway
- 使用數據庫實現動態路由
網關是系統的唯一對外的入口,介于客戶端和服務器端之間的中間層,處理非業務功能,提供路由請求、鑒權、監控、緩存、限流等功能。無論你查看任何一個微服務項目架構,你都會發現在客戶端和服務器端之間有一個網關,移動端的任何請求都必須經過網關才能到達服務端。
網關怎么實現集群:使用nginx實現。
基于nginx部署gateway集群
1、將網關項目多個部署啟動
例如:
網關1 127.0.0.1:81
網關1 127.0.0.1:82
2、各個微服務如何知道是哪個網關請求的
在網關的過濾器中給請求頭添加可以區別網關的信息。
動態Gateway
動態網關:任何配置都實現不用重啟網關服務器都可以及時刷新。
實現思路:
1、分布式配置中心,閱讀性差。
2、基于數據庫表結構設計。
gateway提供對應的接口:1、直接新增路由;2、直接修改路由
使用api添加gateway 路由,直接注入該bean 調用 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() { // 從數據庫查詢配置的網關配置 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的話 則從注冊中心獲取服務 URI uri = UriComponentsBuilder.fromUriString("lb://kaico-member/").build().toUri(); // 定義的路由唯一的id definition.setId("member"); predicate.setName("Path"); //路由轉發地址 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"; } }
使用數據庫實現動態路由
根據上面的案例,將配置信息添加到數據庫中(數據庫表的設計只要符合只用場景就可以了,沒有什么特別要求),在調用相關的api添加到gateway中即可。
參考學習文檔:https://www.cnblogs.com/crazymakercircle/p/11704077.html
官放文檔:https://docs.spring.io/spring-cloud-gateway/docs/3.0.5-SNAPSHOT/reference/html/#gateway-starter