Springboot整合GateWay+Nacos實(shí)現(xiàn)動(dòng)態(tài)路由
1、簡(jiǎn)介
路由轉(zhuǎn)發(fā) + 執(zhí)行過(guò)濾器鏈。
? 網(wǎng)關(guān),旨在為微服務(wù)架構(gòu)提供一種簡(jiǎn)單有效的統(tǒng)一的API路由管理方式。同時(shí),基于Filter鏈的方式提供了網(wǎng)關(guān)的基本功能,比如:鑒權(quán)、流量控制、熔斷、路徑重寫、黑白名單、日志監(jiān)控等。
基本功能如下:
- 統(tǒng)一入口:暴露出網(wǎng)關(guān)地址,作為請(qǐng)求唯一入口,隔離內(nèi)部微服務(wù),保障了后臺(tái)服務(wù)的安全性
- 鑒權(quán)校驗(yàn):識(shí)別每個(gè)請(qǐng)求的權(quán)限,拒絕不符合要求的請(qǐng)求
- 動(dòng)態(tài)路由:動(dòng)態(tài)的將請(qǐng)求路由到不同的后端集群中
2、gateway核心概念
路由(Route):由一個(gè)ID,一個(gè)目標(biāo)URI(最終路由到的url地址),一組斷言(匹配條件判斷)和一組過(guò)濾器定義。如果斷言為真,則路由匹配。
斷言(Predicate):通過(guò)斷言匹配http請(qǐng)求中的任何內(nèi)容(請(qǐng)求頭、請(qǐng)求參數(shù)等),如果匹配成功,則匹配斷言所在路由。
過(guò)濾器(Filter):在請(qǐng)求前后執(zhí)行業(yè)務(wù)邏輯,比如鑒權(quán)、日志監(jiān)控、流量控制、修改請(qǐng)求頭、修改響應(yīng)等。
3、路由
spring: cloud: gateway: routes: - id: manager # 路由唯一標(biāo)識(shí) uri: lb://manager_server # 路由指向目的地URL或服務(wù)名,客戶端請(qǐng)求最終被轉(zhuǎn)發(fā)到的微服務(wù) predicates: - Path=/manager/** # 斷言:以manager開(kāi)頭的請(qǐng)求都負(fù)載到manager_server服務(wù) filters: - RewritePath=/manager/(?<segment>.*), /$\{segment} # 過(guò)濾器:過(guò)濾掉url里的manager,例如http://ip:port/manager/test -> http://ip:port/test order: 5 # 用于多個(gè)Route之間的排序,數(shù)值越小越靠前,匹配優(yōu)先級(jí)越高
4、實(shí)戰(zhàn)練習(xí)
1、項(xiàng)目結(jié)構(gòu)
2、依賴
1、父依賴
<properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <dubbo.version>3.2.0-beta.4</dubbo.version> <spring-boot.version>2.6.11</spring-boot.version> </properties> <dependencyManagement> <dependencies> <!-- Spring Boot --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--springcloudalibaba--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>2021.0.4.0</version> <type>pom</type> <scope>import</scope> </dependency> <!--nacos--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2021.0.4.0</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
2、服務(wù)提供者依賴(provider)
<dependencies> <!-- spring boot starter --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--Nacos--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> </dependencies>
3、網(wǎng)關(guān)依賴(gateway)
<dependencies> <!--gateway--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-gateway --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> <version>3.1.2</version> </dependency> <!--Nacos--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!--客戶端負(fù)載均衡loadbalancer--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-loadbalancer --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-loadbalancer</artifactId> <version>3.1.1</version> </dependency> </dependencies>
3、配置文件
1、服務(wù)提供者1配置(provider)
server: port: 9002 spring: application: name: SpringBoot-Nacos-Dubbo-provider #Nacos注冊(cè)中心服務(wù)名稱 cloud: nacos: discovery: server-addr: 127.0.0.1:8848 #Nacos注冊(cè)中心地址
服務(wù)提供者2復(fù)制修改端口即可
2、gateway配置(路由配置方式1)
server: port: 8080 spring: application: name: gateway cloud: nacos: discovery: server-addr: localhost:8848 #注冊(cè)到nacos中 gateway: routes: - id: gateway1 #路由的ID,沒(méi)有固定規(guī)則但要求唯一,建議配合服務(wù)名 uri: http://localhost:9002 #匹配后提供服務(wù)的路由地址 predicates: - Path=/provider/** # 斷言,路徑相匹配的進(jìn)行路由
4、服務(wù)提供者Controller
@RestController @RequestMapping("/provider") public class ProviderController { @Value("${server.port}") private String post; @GetMapping("/getpost") public String getPost(){ return "當(dāng)前端口:"+post; } }
5、項(xiàng)目啟動(dòng)
啟動(dòng)服務(wù)提供者9002 瀏覽器訪問(wèn)localhost:8080/provider/getpost
6、gateway配置(路由配置方式2(動(dòng)態(tài)配置))
負(fù)載均衡
傳統(tǒng)模式
gateway
1、配置文件
server: port: 8080 spring: application: name: gateway cloud: nacos: discovery: server-addr: localhost:8848 #注冊(cè)到nacos中 gateway: discovery: locator: enabled: true #開(kāi)啟從注冊(cè)中心動(dòng)態(tài)創(chuàng)建路由的功能,利用微服務(wù)名進(jìn)行路由 routes: - id: gateway1 #路由的ID,沒(méi)有固定規(guī)則但要求唯一,建議配合服務(wù)名 uri: lb://SpringBoot-Nacos-Dubbo-provider #匹配后提供服務(wù)的名稱 用于負(fù)載均衡 predicates: - Path=/provider/** # 斷言,路徑相匹配的進(jìn)行路由
分別啟動(dòng)服務(wù)提供者9002、9001 瀏覽器訪問(wèn)localhost:8080/provider/getpost 實(shí)現(xiàn)負(fù)載均衡
到此這篇關(guān)于Springboot整合GateWay+Nacos實(shí)現(xiàn)動(dòng)態(tài)路由的文章就介紹到這了,更多相關(guān)Springboot 動(dòng)態(tài)路由內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Javabean基于xstream包實(shí)現(xiàn)轉(zhuǎn)XML文檔的方法
這篇文章主要介紹了Javabean基于xstream包實(shí)現(xiàn)轉(zhuǎn)XML文檔的方法,結(jié)合具體實(shí)例形式分析了xstream包用于轉(zhuǎn)換xml文件的具體使用技巧,需要的朋友可以參考下2017-05-05Hibernate的Annotation版Hello world實(shí)例
這篇文章主要介紹了Hibernate的Annotation版Hello world實(shí)現(xiàn)方法,詳細(xì)分析了Annotation的具體使用步驟與Hello world實(shí)現(xiàn)方法,需要的朋友可以參考下2016-03-03REST架構(gòu)及RESTful應(yīng)用程序簡(jiǎn)介
這篇文章主要為大家介紹了REST架構(gòu)及RESTful的應(yīng)用程序簡(jiǎn)介,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03Java實(shí)現(xiàn)游戲抽獎(jiǎng)算法
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)游戲抽獎(jiǎng)算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11Java bat批處理命令啟動(dòng)jar包的操作方法
這篇文章主要介紹了JAVA bat批處理命令啟動(dòng)jar包,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-12-12解決JD-GUI for mac big sur打不開(kāi)問(wèn)題
這篇文章主要介紹了解決JD-GUI for mac big sur打不開(kāi)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01