springcloud集成nacos?使用lb?無(wú)效問(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的依賴包如下圖

找到spring.factories 文件并打開(kāi),發(fā)現(xiàn)跟負(fù)載均衡有關(guān)系的配置類有GatewayNoLoadBalancerClientAutoConfiguration和GatewayReactiveLoadBalancerClientAutoConfiguration
這兩個(gè)配置類。根據(jù)名稱可以知道
GatewayNoLoadBalancerClientAutoConfiguration 是不支持負(fù)載均衡客戶端的自動(dòng)配置類。
而GatewayReactiveLoadBalancerClientAutoConfiguration 是支持負(fù)載均衡客戶端配置類。

分別查看一下這兩個(gè)配置類
GatewayNoLoadBalancerClientAutoConfiguration 代碼如下

可以看出這個(gè)配置類就干了一個(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ò)查詢官網(wǎng)文檔,得知使用負(fù)載均衡需要依賴
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

添加以上依賴,重新編譯,啟動(dòng)程序,執(zhí)行請(qǐng)求成功。完美解決問(wèn)題!
參考資料
總結(jié):
通過(guò)查看spring-cloud-starter-gateway jar中的自動(dòng)配置類的源碼。得知,該jar包中是不支持負(fù)載均衡的,需要引入spring-cloud-starter-loadbalancer 來(lái)支持。
到此這篇關(guān)于解決springcloud集成nacos 使用lb 無(wú)效的文章就介紹到這了,更多相關(guān)springcloud集成nacos內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java封裝實(shí)現(xiàn)自適應(yīng)的單位轉(zhuǎn)換工具類
這篇文章主要為大家詳細(xì)介紹了如何使用Java封裝實(shí)現(xiàn)一個(gè)自適應(yīng)的單位轉(zhuǎn)換工具類,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-03-03
java實(shí)現(xiàn)圖片上加文字水印(SpringMVC + Jsp)
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)在圖片上加文字水印的方法,水印可以是圖片或者文字,操作方便,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05
SpringBoot中的ThreadLocal保存請(qǐng)求用戶信息的實(shí)例demo
線程局部變量,創(chuàng)建一個(gè)線程變量后,針對(duì)這個(gè)變量可以讓每個(gè)線程擁有自己的變量副本,每個(gè)線程是訪問(wèn)的自己的副本,與其他線程的相互獨(dú)立,本文介紹SpringBoot中的ThreadLocal保存請(qǐng)求用戶信息,需要的朋友可以參考下2024-05-05
Java實(shí)現(xiàn)Excel轉(zhuǎn)PDF的兩種方法詳解
使用具將Excel轉(zhuǎn)為PDF的方法有很多,在這里我給大家介紹兩種常用的方法:使用spire轉(zhuǎn)化PDF、使用jacob實(shí)現(xiàn)Excel轉(zhuǎn)PDF,分別應(yīng)對(duì)兩種不一樣的使用場(chǎng)景,需要的可以參考一下2022-01-01

