深入剖析網(wǎng)關gateway原理
一 背景
微服務架構提供一種簡單有效的統(tǒng)一的 API入口
負責服務請求路由、組合及協(xié)議轉(zhuǎn)換,并且基于 Filter 鏈的方式提供了權限認證,監(jiān)控、限流等功能。
- 優(yōu)點:
性能強勁:是第一代網(wǎng)關Zuul的1.6倍。
功能強大:內(nèi)置了很多實用的功能,例如轉(zhuǎn)發(fā)、監(jiān)控、限流等設計優(yōu)雅,容易擴展。
- 缺點:
依賴Netty與WebFlux(Spring5.0),不是傳統(tǒng)的Servlet編程模型(Spring MVC就是基于此模型實現(xiàn)),學習成本高。需要Spring Boot 2.0及以上的版本,才支持
二需要的依賴:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
添加配置文件及說明:
server:
port: 9000
spring:
application:
name: sca-gateway
cloud:
gateway:
routes: #配置網(wǎng)關路由規(guī)則
- id: route01 #路由id,自己指定一個唯一值即可
uri: http://localhost:8081/ #網(wǎng)關幫我們轉(zhuǎn)發(fā)的url
predicates: ###斷言(謂此):匹配請求規(guī)則
- Path=/nacos/provider/echo/** #請求路徑定義,此路徑對應uri中的資源
filters: ##網(wǎng)關過濾器,用于對謂詞中的內(nèi)容進行判斷分析以及處理
- StripPrefix=1 #轉(zhuǎn)發(fā)之前去掉path中第一層路徑,例如nacos
說明
路由(Route) 是 gateway 中最基本的組件之一
表示一個具體的路由信息載體。
主要定義了下面的幾個信息:
id,路由標識符,區(qū)別于其他 Route。
uri,路由指向的目的地 uri,即客戶端請求最終被轉(zhuǎn)發(fā)到的微服務。
predicate,斷言(謂詞)的作用是進行條件判斷,只有斷言都返回真,才會執(zhí)行路由。
filter,過濾器用于修改請求和響應信息。
什么是網(wǎng)關?
服務訪問(流量)的一個入口,類似生活中的“海關“
為什么使用網(wǎng)關?
服務安全,統(tǒng)一服務入口管理,負載均衡,限流,鑒權
Spring Cloud Gateway 應用的初始構建過程(添加依賴,配置
Gateway 服務的啟動底層是通過誰去實現(xiàn)的?
Netty網(wǎng)絡編程框架-ServerSocket
Gateway 服務做請求轉(zhuǎn)發(fā)時一定要在注冊中心進行注冊嗎?
不一定,可以直接通過遠端url進行服務訪問
三 負載均衡
需要的porm文件是nacos的配置和包,是通過nacos配置中心,尋找實例。
網(wǎng)關層面是如何實現(xiàn)負載均衡的?
通過服務名去查找具體的服務實例
網(wǎng)關層面是如何通過服務名查找服務實例的?
Ribbon
你了解Ribbon中的哪些負載均衡算法?
輪詢,權重,hash,……可通過IRule接口進行查看分析
網(wǎng)關進行請求轉(zhuǎn)發(fā)的流程是怎樣,有哪些關鍵對象?
XxxHandlerMapping,Handler,。。。
網(wǎng)關層面服務的映射方式怎樣的?
謂詞-path,…,服務名/服務實例
網(wǎng)關層如何記錄服務的映射?
通過map,并要考慮讀寫鎖的應用
下圖是定義在網(wǎng)關層面定義全局過濾器

網(wǎng)關(Gateway)
誕生的背景?
第一:統(tǒng)一微服務訪問的入口,
第二:對系統(tǒng)服務進行保護,
第三進行統(tǒng)一的認證,授權,限流
網(wǎng)關的選型?
Netifix Zuul,Spring Cloud Gateway,…
Spring Cloud Gateway的入門實現(xiàn)
添加依賴,路由配置,啟動類
Spring Cloud Gateway中的負載均衡?
網(wǎng)關服務注冊,服務的發(fā)現(xiàn),基于uri:lb://服務id方式訪問具體服務實例
Spring Cloud Gateway中的斷言配置?
掌握常用幾個就可,用時可以通過搜索引擎去查
Spring Cloud Gateway中的過濾器配置?
掌握過濾器中的兩大類型-局部和全局
Spring Cloud Gateway中的限流設計?
Sentinel
Gateway在互聯(lián)網(wǎng)架構中的位置?
nginx->gateway–>微服務–>微服務
Gateway底層負載均衡的實現(xiàn)?
Ribbon
Gateway應用過程中設計的主要概念?
路由id,路由uri,斷言,過濾器
Gateway中你做過哪些斷言配置?
after,header,path,cookie,…
Gateway中你用的過濾器有哪些?
添加前綴,去掉前綴,添加請求頭,…,負載均衡,…
以上就是深入理解網(wǎng)關gateway的詳細內(nèi)容,更多關于網(wǎng)關gateway的資料請關注腳本之家其它相關文章!
相關文章
git可視化工具Sourcetree使用全攻略(git沖突解決)
本文主要介紹了git可視化工具Sourcetree使用全攻略,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01
在Visual Studio Code環(huán)境中使用SVN的方案
這篇文章主要介紹了在Visual Studio Code環(huán)境中使用SVN的方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04
踩坑記錄關于"authentication failed "的解決方法
今天給大家分享我的踩坑記錄關于報錯 authentication failed,這個報錯的原因是“身份驗證失敗”,本文給大家分享我的解決方法,感興趣的朋友跟隨小編一起看看吧2023-01-01

