解決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)文章
詳談cxf和axis兩種框架下的webservice客戶端開發(fā)
這篇文章主要介紹了詳談cxf和axis兩種框架下的webservice客戶端開發(fā),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
Java的ConcurrentLinkedQueue源碼分析
這篇文章主要介紹了Java的ConcurrentLinkedQueue源碼分析,ConcurrentLinkedQueue 是一個基于鏈接節(jié)點的無界線程安全的隊列,當(dāng)我們添加一個元素的時候,它會添加到隊列的尾部,當(dāng)我們獲取一個元素時,它會返回隊列頭部的元素,需要的朋友可以參考下2023-12-12
Mybatis Plus 實現(xiàn)批量插入的示例代碼
本文主要介紹了Mybatis Plus 實現(xiàn)批量插入的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09

