SpringCloud超詳細(xì)講解微服務(wù)網(wǎng)關(guān)Zuul
網(wǎng)關(guān)的作用
微服務(wù)架構(gòu)中,服務(wù)實(shí)例的地址可能經(jīng)常會發(fā)生變化,所以我們不能直接將服務(wù)的地址暴露出來。如果每一個微服務(wù)都直接暴露接口,會導(dǎo)致一系列的問題,比如調(diào)用過于復(fù)雜,涉及到賬戶、權(quán)限不能統(tǒng)一處理等。另外基于高內(nèi)聚低耦合的設(shè)計(jì)準(zhǔn)則來講,我們也應(yīng)該將內(nèi)部系統(tǒng)和外部系統(tǒng)做切割。
因此,這時就需要有一個獨(dú)立的組件來處理外部的請求,這個組件就是服務(wù)網(wǎng)關(guān)。服務(wù)網(wǎng)關(guān)就是為了簡化前端的調(diào)用邏輯,通常情況下也會實(shí)現(xiàn)相關(guān)的認(rèn)證邏輯,根據(jù)外部不同的請求響應(yīng)不同的數(shù)據(jù),從而簡化內(nèi)外部系統(tǒng)之間調(diào)用的復(fù)雜度。
服務(wù)網(wǎng)關(guān)負(fù)責(zé)服務(wù)請求路由、組合及協(xié)議轉(zhuǎn)換??蛻舳说乃姓埱蠖际紫冉?jīng)過服務(wù)網(wǎng)關(guān),然后由它將請求路由到合適的微服務(wù)。服務(wù)網(wǎng)關(guān)經(jīng)常會通過調(diào)用多個微服務(wù)并合并結(jié)果來處理一個請求,它可以在系統(tǒng)外部與內(nèi)部響應(yīng)之間友好的轉(zhuǎn)換。
本文將先著重介紹Zuul組件。
Spring Cloud 網(wǎng)關(guān)組件Zuul介紹
Zuul 是 Netflix 公司開源的產(chǎn)品,被稱為第一代網(wǎng)關(guān),也是 Spring Cloud 前幾個版本默認(rèn)使用的一款提供動態(tài)路由微服務(wù)網(wǎng)關(guān)組件。Zuul 接收所有外來請求,并將請求轉(zhuǎn)發(fā)到對應(yīng)的后端服務(wù)。作為一個前置服務(wù),Zuul 旨在實(shí)現(xiàn)動態(tài)路由,監(jiān)控,彈性和安全性等功能。
Zuul 提供了不同類型的 filter 用于處理請求,這些 filter 可以讓我們實(shí)現(xiàn)以下功能:
- 權(quán)限控制和安全性:可以識別認(rèn)證需要的信息和拒絕不滿足條件的請求。
- 監(jiān)控:與邊緣位置追蹤有意義的數(shù)據(jù)和統(tǒng)計(jì)結(jié)果,從而帶來精確的生產(chǎn)視圖。
- 動態(tài)路由:根據(jù)需要動態(tài)地路由請求到后臺的不同集群。
- 壓力測試:逐漸增加指向集群的流量,以了解性能。
- 負(fù)載均衡:為每一種負(fù)載類型分配對應(yīng)容量,并棄用超出限定值的請求
- 靜態(tài)資源處理:直接在 zuul 處理靜態(tài)資源的響應(yīng),從而避免其轉(zhuǎn)發(fā)到內(nèi)部集群。
Zuul網(wǎng)關(guān)實(shí)戰(zhàn)
之前的介紹中,我們啟動了注冊中心registry,dms服務(wù),和app服務(wù),請求時,直接調(diào)用了app服務(wù)的接口,app服務(wù)又調(diào)用了dms服務(wù):
加上網(wǎng)關(guān)服務(wù)之后,就會變成如下:
接下來,我們創(chuàng)建zuul服務(wù):
1、創(chuàng)建服務(wù)
創(chuàng)建子模塊zuul,pom.xml引入eureka-client 和zuul的依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <!-- feign --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <!-- zuul路由 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-zuul</artifactId> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> </dependency>
2、創(chuàng)建配置文件
server:
port: 8004
spring:
application:
name: zuuleureka:
client:
service-url:
defaultZone: http://localhost:8001/eureka/
feign:
hystrix:
enabled: true
zuul:
routes:
app: #活動
path: /app/** #配置請求URL的請求規(guī)則
serviceId: app #指定Eureka注冊中心中的服務(wù)id
dms: #活動
path: /dms/** #配置請求URL的請求規(guī)則
serviceId: dms #指定Eureka注冊中心中的服務(wù)id
logging:
pattern:
console: '%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%thread] %logger{15} - %msg%n'
3、創(chuàng)建Zuul過濾器
public class MyZuulFilter extends ZuulFilter { // pre :可以在請求被路由之前調(diào)用 // route :在路由請求時候被調(diào)用 // post :在route和error過濾器之后被調(diào)用 // error :處理請求時發(fā)生錯誤時被調(diào)用 @Override public String filterType() { return "pre";// 前置過濾器 } //通過int值來定義過濾器的執(zhí)行順序,優(yōu)先級為0,數(shù)字越大,優(yōu)先級越低 @Override public int filterOrder() { return 0; } //返回一個boolean類型來判斷該過濾器是否要執(zhí)行,所以通過此函數(shù)可實(shí)現(xiàn)過濾器的開關(guān) @Override public boolean shouldFilter() { return true;//此處為true,說明需要過濾 } //過濾器的具體邏輯。 @Override public Object run() throws ZuulException { // 獲取上下文 RequestContext currentContext = RequestContext.getCurrentContext(); HttpServletRequest request = currentContext.getRequest(); String accessToken = request.getParameter("accessToken"); if (StringUtils.isEmpty(accessToken)) { //setSendZuulResponse(false)令zuul過濾該請求,不進(jìn)行路由 currentContext.setSendZuulResponse(false); //設(shè)置返回的錯誤碼 currentContext.setResponseStatusCode(401); currentContext.setResponseBody("AccessToken is null"); return null; } System.out.println("獲取到AccessToken為:"+accessToken); // 否則正常執(zhí)行業(yè)務(wù)邏輯..... return null; } }
4、編寫啟動類
注意增加@EnableZuulProxy注解
@EnableZuulProxy @EnableEurekaClient @SpringBootApplication public class ZuulApplication { public static void main(String[] args) { SpringApplication.run(ZuulApplication.class, args); } }
5、啟動驗(yàn)證
這個時候,我們將直接請求app的接口地址,改成網(wǎng)關(guān)zuul的地址和端口:http://localhost:8004/app/index
可以看到,請求中沒有token訪問授權(quán)認(rèn)證失敗!
總結(jié)
總結(jié)下網(wǎng)關(guān)的作用:
- 簡化客戶端調(diào)用的復(fù)雜度,統(tǒng)一處理外部請求。
- 數(shù)據(jù)的裁剪和聚合,根據(jù)不同的接口需求,對數(shù)據(jù)加工后對外提供接口
- 多平臺的支持,對不同的客戶端提供不同的網(wǎng)關(guān)支持。
- 遺留系統(tǒng)的微服務(wù)化改造,可以作為新老系統(tǒng)的中轉(zhuǎn)組件。
- 統(tǒng)一處理調(diào)用過程中的安全、權(quán)限問題。
到此這篇關(guān)于SpringCloud超詳細(xì)講解微服務(wù)網(wǎng)關(guān)Zuul的文章就介紹到這了,更多相關(guān)SpringCloud Zuul內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot3利用AOP實(shí)現(xiàn)IP黑名單功能
在Web應(yīng)用開發(fā)中,控制對特定IP地址的訪問權(quán)限是一個常見的需求,通過實(shí)現(xiàn)IP黑白名單功能,我們可以允許某些IP地址訪問應(yīng)用,同時拒絕其他IP地址的訪問,本文將詳細(xì)介紹SpringBoot3利用AOP實(shí)現(xiàn)IP黑名單功能,并附上相應(yīng)的代碼片段,需要的朋友可以參考下2024-09-09Spring?main方法中如何調(diào)用Dao層和Service層的方法
這篇文章主要介紹了Spring?main方法中調(diào)用Dao層和Service層的方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12springboot中在非bean類中調(diào)用bean的實(shí)現(xiàn)方法
在Spring Boot中,非Bean類調(diào)用Bean方法通常需要通過靜態(tài)方法獲取Bean實(shí)例,然后調(diào)用相應(yīng)的方法,這種方法避免了直接在非Bean類中注入Bean,保持了代碼的簡潔和可維護(hù)性,通過這種方式,可以在不改變原有代碼結(jié)構(gòu)的情況下,實(shí)現(xiàn)Bean方法的調(diào)用2025-02-02關(guān)于SpringBoot創(chuàng)建存儲令牌的媒介類和過濾器的問題
這篇文章主要介紹了SpringBoot創(chuàng)建存儲令牌的媒介類和過濾器的問題,需要在配置文件中,添加JWT需要的密匙,過期時間和緩存過期時間,具體實(shí)例代碼參考下本文2021-09-09