這篇文章將為大家詳細講解有關(guān)Spring Cloud Gateway的動態(tài)路由及集成Nacos實現(xiàn)示例分析,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
創(chuàng)新互聯(lián)專注于梁河企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站定制開發(fā)。梁河網(wǎng)站建設(shè)公司,為梁河等地區(qū)提供建站服務(wù)。全流程按需開發(fā)網(wǎng)站,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
網(wǎng)關(guān)的核心概念就是路由配置和路由規(guī)則,而作為所有請求流量的入口,在實際生產(chǎn)環(huán)境中為了保證高可靠和高可用,是盡量要避免重啟的,所以實現(xiàn)動態(tài)路由是非常有必要的;下面主要介紹 Spring Cloud Gateway
實現(xiàn)的思路,并且以Nacos
為數(shù)據(jù)源來講解
要實現(xiàn)動態(tài)路由只需關(guān)注下面4個點
網(wǎng)關(guān)啟動時,動態(tài)路由
的數(shù)據(jù)怎樣加載進來
靜態(tài)路由
與動態(tài)路由
以那個為準,ps:靜態(tài)路由
指的是配置文件里寫死的路由配置
監(jiān)聽動態(tài)路由
的數(shù)據(jù)源變化
數(shù)據(jù)有變化時怎樣通知gateway
刷新路由
Spring Cloud Gateway
中加載路由信息分別由以下幾個類負責
PropertiesRouteDefinitionLocator:從配置文件中讀取路由信息(如YML、Properties等)
RouteDefinitionRepository:從存儲器中讀取路由信息(如內(nèi)存、配置中心、redis、MySQL等)
DiscoveryClientRouteDefinitionLocator:從注冊中心中讀取路由信息(如Nacos、Eurka、Zookeeper等)
我們可以通過自定義 RouteDefinitionRepository
的實現(xiàn)類來實現(xiàn)動態(tài)路由的目的
創(chuàng)建一個Nacos
的RouteDefinitionRepository
實現(xiàn)類
NacosRouteDefinitionRepository
重寫
getRouteDefinitions
方法實現(xiàn)路由信息的讀取
配置Nacos監(jiān)聽器,監(jiān)聽路由配置信息的變化
路由變化只需要往
ApplicationEventPublisher
推送一個RefreshRoutesEvent
事件即可,gateway會自動監(jiān)聽該事件并調(diào)用getRouteDefinitions
方法更新路由信息
DynamicRouteConfig
Nacos
路由配置新增配置項:
Data Id:scg-routes
Group:SCG_GATEWAY
配置內(nèi)容:
[ { "id": "csdn", "predicates": [{ "name": "Path", "args": { "pattern": "/csdn/**" } }], "uri": "https://www.csdn.net/", "filters": [] }, { "id": "github", "predicates": [{ "name": "Path", "args": { "pattern": "/github/**" } }], "uri": "http://github.com/", "filters": [] } ]
添加兩條路由數(shù)據(jù)
啟動網(wǎng)關(guān)通過 /actuator/gateway/routes
端點查看當前路由信息
可以看到
Nacos
里配置的兩條路由信息
關(guān)于Spring Cloud Gateway的動態(tài)路由及集成Nacos實現(xiàn)示例分析就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。