首頁 > 軟體

Nginx gateway叢集和動態閘道器的實現思路

2022-10-20 14:04:30

閘道器是系統的唯一對外的入口,介於使用者端和伺服器端之間的中間層,處理非業務功能,提供路由請求、鑑權、監控、快取、限流等功能。無論你檢視任何一個微服務專案架構,你都會發現在使用者端和伺服器端之間有一個閘道器,行動端的任何請求都必須經過閘道器才能到達伺服器端。

閘道器怎麼實現叢集:使用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/

到此這篇關於Nginx gateway叢集和動態閘道器的文章就介紹到這了,更多相關Nginx gateway叢集內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com