springcloud集成nacos?使用lb?無效問題解決方案
背景
最近在搭建微服務(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ù)載均衡。
所以問題就定位到了,是因?yàn)槿鄙貺oadBalancerAutoConfiguration和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 使用lb 無效的文章就介紹到這了,更多相關(guān)springcloud集成nacos內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java?LocalDateTime獲取時間信息、格式化、轉(zhuǎn)換為數(shù)字時間戳代碼示例
其實(shí)我們在Java項(xiàng)目中對日期進(jìn)行格式化,主要是利用一些日期格式化類,下面這篇文章主要給大家介紹了關(guān)于Java?LocalDateTime獲取時間信息、格式化、轉(zhuǎn)換為數(shù)字時間戳的相關(guān)資料,需要的朋友可以參考下2023-11-11SpringMVC通過攔截器實(shí)現(xiàn)IP黑名單
這篇文章主要為大家詳細(xì)介紹了SpringMVC通過攔截器實(shí)現(xiàn)IP黑名單,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-08-08Spring的FactoryBean<Object>接口示例代碼
FactoryBean是Spring框架中的一個接口,用于創(chuàng)建和管理Bean對象,它的作用是將Bean的創(chuàng)建過程交給FactoryBean實(shí)現(xiàn)類來完成,而不是直接由Spring容器來創(chuàng)建,本文給大家介紹Spring的FactoryBean<Object>接口,感興趣的朋友一起看看吧2023-11-11Java在Map轉(zhuǎn)Json字符串時出現(xiàn)"\"轉(zhuǎn)義字符的解決辦法
當(dāng)一個Map被轉(zhuǎn)成Json字符串后,被添加到另一個Map中,會出現(xiàn)被加上“\”轉(zhuǎn)義字符的情況,這個時候該如何解決呢,下面就來和小編一起了解一下2023-07-07SpringCloud Feign遠(yuǎn)程調(diào)用與自定義配置詳解
Feign是Netflix公司開發(fā)的一個聲明式的REST調(diào)用客戶端; Ribbon負(fù)載均衡、 Hystrⅸ服務(wù)熔斷是我們Spring Cloud中進(jìn)行微服務(wù)開發(fā)非?;A(chǔ)的組件,在使用的過程中我們也發(fā)現(xiàn)它們一般都是同時出現(xiàn)的,而且配置也都非常相似2022-11-11JavaEE組件commons-fileupload實(shí)現(xiàn)文件上傳、下載
這篇文章主要介紹了JavaEE組件commons-fileupload實(shí)現(xiàn)文件上傳、下載,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10