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