SpringCloud中Gateway的使用教程詳解
1.基礎(chǔ)教程
pom.xml
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.6</version>
</parent>
<dependencies>
<!--gateway不是通過servlet啟動的,不需要spring-boot-starter-web-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>2020.0.6</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement> application.yml
server: port: 8081
springboot啟動類
@SpringBootApplication
public class GateWayApplication {
public static void main(String[] args) {
SpringApplication.run(GateWayApplication.class,args);
}
@Bean
public RouteLocator myRoutes(RouteLocatorBuilder builder) {
return builder.routes()
.route(p -> p
.path("/**")
.filters(f -> f.addRequestParameter("aa","bb"))
.uri("http://localhost:18080"))
.build();
}
}
以上代碼,是做了個路由:如果url的path符合正則“/**”則給請求添加一個aa=bb的參數(shù)然后轉(zhuǎn)發(fā)到http://localhost:18080,。
如果訪問http://localhost:8081/get,則最終會請求http://localhost:18080/get?aa=bb
我們再添加一個route。
@SpringBootApplication
public class GateWayApplication {
public static void main(String[] args) {
SpringApplication.run(GateWayApplication.class,args);
}
@Bean
public RouteLocator myRoutes(RouteLocatorBuilder builder) {
return builder.routes()
.route(p ->p
.method("POST")
.uri("http://localhost:18081")
)
.route(p -> p
.path("/**")
.filters(f -> f.addRequestParameter("aa","bb"))
.uri("http://localhost:18080"))
.build();
}
}
以上代碼添加了一個如果是POST訪問,則轉(zhuǎn)發(fā)到http://localhost:18081。
那么如果我們使用POST的http://localhost:8081/aaa,則會轉(zhuǎn)發(fā)到http://localhost:18081/aaa.
值得注意的是,如果這兩個route換下位置,path=/** 的route放在method=post的上面,則會產(chǎn)生另外的情況,就是會轉(zhuǎn)發(fā)到18080上去,因為POST的http://localhost:8081/aaa也會匹配上/** .這些route是有先后順序的。
可以看出route有一個重要的概念,就是條件predicate,命中了什么條件就會被轉(zhuǎn)發(fā)到哪里。
Predicate來自于java8的接口。Predicate 接受一個輸入?yún)?shù),返回一個布爾值結(jié)果。該接口包含多種默認方法來將Predicate組合成其他復(fù)雜的邏輯(比如:與,或,非)??梢杂糜诮涌谡埱髤?shù)校驗、判斷新老數(shù)據(jù)是否有變化需要進行更新操作。add–與、or–或、negate–非。
Spring Cloud Gateway內(nèi)置了許多Predict,這些Predict的源碼在org.springframework.cloud.gateway.handler.predicate包中,如果讀者有興趣可以閱讀一下。現(xiàn)在列舉各種Predicate如下圖:

可以看到這有幾種類型的Predict,而我們剛剛使用的就是METHOD和Path這兩種,當然你可以選擇其他的。
2.將配置放在配置文件里
總是寫些Bean實際上還是不爽,不如我們放在配置文件里面。放配置文件里面可以減少代碼量,最重要的是,如果配合springcloudconfig,可以做到在線更新,這就很爽了。
我們將上面的那個bean注釋掉,然后把上面的寫到配置文件里。
server:
port: 8081
spring:
cloud:
gateway:
routes:
- id: my_method_route
uri: http://localhost:18081
predicates:
- Method=POST
- id: my_path_route
uri: http://localhost:18080
predicates:
- Path=/**
注意一些關(guān)鍵的地方,要約定大于配置比如:Method=POST Path=/**
3.放在springcloud里面
目前我們都是一個單機springboot,跟springcloud沒有關(guān)系。我們嘗試將這段配置放在nacos的config里面。
nacos新建gateway-test.yaml,類型yaml,內(nèi)容如下:
spring:
cloud:
gateway:
routes:
- id: my_path_route
uri: http://localhost:18080
predicates:
- Path=/**
- id: my_method_route
uri: http://localhost:18081
predicates:
- Method=POST
java項目的pom修改下,添加了nacos的服務(wù)發(fā)現(xiàn)和配置文件。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.6</version>
</parent>
<dependencies>
<!--<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<!--springboot2.4版本之后需要添加下面依賴才能加載bootstrap.yml-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>2020.0.6</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!-- SpringCloud Alibaba 微服務(wù) -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2021.1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
添加bootstrap.yml,添加了nacos的一些配置
spring:
application:
name: gateway
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
config:
server-addr: 127.0.0.1:8848
file-extension: yaml修改application.yml
server:
port: 8081
spring:
profiles:
active: test
此時
{{spring.application.name}}-{{spring.profiles.active}}.{{spring.cloud.nacos.config.file-extension}}
正好等于我們剛才在nacos上建的gateway-test.yaml
最后是java啟動執(zhí)行,發(fā)現(xiàn)gateway就從nacos拉取配置文件生效了。
4.使用服務(wù)名而不是IP
我們的uri轉(zhuǎn)發(fā)的都是具體的ip地址,那么真正在微服務(wù)的時候,肯定轉(zhuǎn)發(fā)的是服務(wù)名而不是ip地址。
修改gateway-test.yaml里面的uri,boot-cloud和boot-cloud1是我們創(chuàng)建的另兩個服務(wù)。
spring:
cloud:
gateway:
routes:
- id: my_path_route
uri: lb://boot-cloud
predicates:
- Path=/**
- id: my_method_route
uri: lb://boot-cloud1
predicates:
- Method=POST
lb是對服務(wù)進行負載均衡的意思,需要添加依賴
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
啟動后,就可以對服務(wù)進行轉(zhuǎn)發(fā)了。
到此這篇關(guān)于SpringCloud中Gateway的使用教程詳解的文章就介紹到這了,更多相關(guān)SpringCloud Gateway內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解java如何實現(xiàn)帶RequestBody傳Json參數(shù)的GET請求
在調(diào)試Fate平臺時,遇到了一個奇葩的接口類型,該接口為Get方式,入?yún)⑹且粋€json類型在body中傳遞,使用body中傳參的話為什么不用POST請求而使用了GET請求,下面我們就來深入研究一下2024-02-02
java 過濾器filter防sql注入的實現(xiàn)代碼
下面小編就為大家?guī)硪黄猨ava 過濾器filter防sql注入的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
springboot項目打包鏡像方式以及區(qū)分環(huán)境打包的方法
本文主要介紹了springboot項目打包鏡像方式以及區(qū)分環(huán)境打包的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-03-03

