解決springcloud集成nacos遇到的問題
背景
最近在搭建微服務(wù)框架,在搭建gateway 的時候 使用nacos做注冊中心,在通過網(wǎng)關(guān)調(diào)用的時候發(fā)下一個奇怪的問題,網(wǎng)關(guān)可以路由http地址,不能路由lb 的地址,路由lb 就報503。下面記錄一下解決的方式。
組件版本
spring-boot-dependencies:2.6.13
spring-cloud-alibaba-dependencies:2021.0.5.0
spring-cloud-dependencies:2021.0.5
分析
先看一下gateway 配置文件信息
server: port: 8088 spring: application: name: api-gateway cloud: #網(wǎng)關(guān)配置 gateway: #路由配置 routes: - id: order_route #路由唯一標(biāo)識 uri: http://localhost:8090 # uri: lb://order-service predicates: # 斷言規(guī)則 - Path=/order-service/** filters: - StripPrefix=1 # 放路徑訪問不到 返回404 # loadbalancer: # use404: true # nacos 地址 nacos: server-addr: 192.168.57.101:8848 discovery: namespace: public
當(dāng)url 使用的是http://localhost:8090 時,請求接口成功。
當(dāng)使用lb://order-service 時 ,接口請求就拋出503 異常
一開始我以為order服務(wù)沒有注冊到nacos上,去查看了一下nacos 發(fā)現(xiàn)服務(wù)是注冊成功的。且網(wǎng)關(guān)和order服務(wù)也都注冊到同一個namespace下且是同一個分組,不可能拿不到order服務(wù)的信息的。
為啥http 可以 lb 就不可以呢,難道spring-cloud-starter-gateway 這個配置中沒有使用本地負(fù)載均衡嗎。
想到這里,決定看一下服務(wù)啟動時從spring-cloud-starter-gateway這個包都自動裝載了哪些配置。
解決步驟
第一步:
在External libraries 中找到gateway的依賴包如下圖
找到spring.factories 文件并打開,發(fā)現(xiàn)跟負(fù)載均衡有關(guān)系的配置類有GatewayNoLoadBalancerClientAutoConfiguration和GatewayReactiveLoadBalancerClientAutoConfiguration
這兩個配置類。根據(jù)名稱可以知道
GatewayNoLoadBalancerClientAutoConfiguration 是不支持負(fù)載均衡客戶端的自動配置類。
而GatewayReactiveLoadBalancerClientAutoConfiguration 是支持負(fù)載均衡客戶端配置類。
分別查看一下這兩個配置類
GatewayNoLoadBalancerClientAutoConfiguration 代碼如下
可以看出這個配置類就干了一個事,向容器中注入一個NoLoadBalancerClientFilter過濾器。該過濾器的過濾方法就是當(dāng)發(fā)現(xiàn)url 中配置的是lb 約束 時拋出NotFoundException異常。
查看創(chuàng)建異常方法
以為with404 這個參數(shù)從配置文件中配置的,默認(rèn)值是false。所以該方法會拋出503異常。
GatewayReactiveLoadBalancerClientAutoConfiguration代碼如下
查看可以得知在spring-cloud-starter-gateway jar包中缺少LoadBalancerAutoConfiguration和LoadBalancerClientFactory,所以GatewayReactiveLoadBalancerClientAutoConfiguration就不會被加載,更不會注入ReactiveLoadBalancerClientFilter bean。
所以spring-cloud-starter-gateway jar 包中只會有NoLoadBalancerClientFilter 不支持負(fù)載均衡。
所以問題就定位到了,是因為缺少LoadBalancerAutoConfiguration和LoadBalancerClientFactory 導(dǎo)致ReactiveLoadBalancerClientFilter 不能注入到容器中。所以只要將包含LoadBalancerClientFactory 的jar包添加到pom 文件中即可。
通過查詢官網(wǎng)文檔,得知使用負(fù)載均衡需要依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-loadbalancer</artifactId> </dependency>
添加以上依賴,重新編譯,啟動程序,執(zhí)行請求成功。完美解決問題!
總結(jié):
通過查看spring-cloud-starter-gateway jar中的自動配置類的源碼。得知,該jar包中是不支持負(fù)載均衡的,需要引入spring-cloud-starter-loadbalancer 來支持。
到此這篇關(guān)于解決springcloud集成nacos遇到的問題的文章就介紹到這了,更多相關(guān)springcloud集成nacos問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Jackson中json格式的字符串與對象的互相轉(zhuǎn)換方式
這篇文章主要介紹了Jackson中json格式的字符串與對象的互相轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07java使用Validation進(jìn)行數(shù)據(jù)校驗的方式總結(jié)
在Java中提供了一系列的校驗方式,下面這篇文章主要給大家介紹了關(guān)于java使用Validation進(jìn)行數(shù)據(jù)校驗的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06Java使用數(shù)組實現(xiàn)ArrayList的動態(tài)擴容的方法
這篇文章主要介紹了Java使用數(shù)組實現(xiàn)ArrayList的動態(tài)擴容的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06Java中==與equals()及hashcode()三者之間的關(guān)系詳解
最近也是在讀Hollis的《深入理解Java核心技術(shù)》里面一節(jié)講到了equals()和hashcode()的關(guān)系,對于這個高頻面試點,咱們需要認(rèn)真理清一下幾者之間的關(guān)系2022-10-10springboot中使用mybatisplus自帶插件實現(xiàn)分頁的示例代碼
這篇文章主要介紹了springboot中使用mybatisplus自帶插件實現(xiàn)分頁,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09在IntelliJ IDEA 搭建springmvc項目配置debug的教程詳解
這篇文章主要介紹了在IntelliJ IDEA 搭建springmvc項目配置debug的教程詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09使用監(jiān)聽器對Spring bean id進(jìn)行唯一校驗過程解析
這篇文章主要介紹了使用監(jiān)聽器對Spring bean id進(jìn)行唯一校驗過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-08-08