解决springcloud集成nacos 使用lb 无效

背景

最近在搭建微服务框架,在搭建gateway 的时候 使用nacos做注册中心,在通过网关调用的时候发下一个奇怪的问题,网关可以路由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:
    #网关配置
    gateway:
      #路由配置
      routes:
        - id: order_route       #路由唯一标识
          uri: http://localhost:8090
#          uri: lb://order-service
          predicates:    # 断言规则
            - Path=/order-service/**
          filters:
            - StripPrefix=1 
      # 放路径访问不到 返回404
   #   loadbalancer:
   #     use404: true
        
    # nacos 地址
    nacos:
      server-addr: 192.168.57.101:8848
      discovery:
        namespace: public
        

当url 使用的是http://localhost:8090 时,请求接口成功。
在这里插入图片描述

当使用lb://order-service 时 ,接口请求就抛出503 异常
在这里插入图片描述
一开始我以为order服务没有注册到nacos上,去查看了一下nacos 发现服务是注册成功的。且网关和order服务也都注册到同一个namespace下且是同一个分组,不可能拿不到order服务的信息的。
在这里插入图片描述
为啥http 可以 lb 就不可以呢,难道spring-cloud-starter-gateway 这个配置中没有使用本地负载均衡吗。
想到这里,决定看一下服务启动时从spring-cloud-starter-gateway这个包都自动装载了哪些配置。

解决步骤

第一步:

在External libraries 中找到gateway的依赖包如下图
在这里插入图片描述
找到spring.factories 文件并打开,发现跟负载均衡有关系的配置类有GatewayNoLoadBalancerClientAutoConfigurationGatewayReactiveLoadBalancerClientAutoConfiguration
这两个配置类。根据名称可以知道
GatewayNoLoadBalancerClientAutoConfiguration 是不支持负载均衡客户端的自动配置类。
而GatewayReactiveLoadBalancerClientAutoConfiguration 是支持负载均衡客户端配置类。

在这里插入图片描述

分别查看一下这两个配置类

GatewayNoLoadBalancerClientAutoConfiguration 代码如下
在这里插入图片描述
可以看出这个配置类就干了一个事,向容器中注入一个NoLoadBalancerClientFilter过滤器。该过滤器的过滤方法就是当发现url 中配置的是lb 约束 时抛出NotFoundException异常。
查看创建异常方法
在这里插入图片描述
以为with404 这个参数从配置文件中配置的,默认值是false。所以该方法会抛出503异常。

GatewayReactiveLoadBalancerClientAutoConfiguration代码如下
在这里插入图片描述
查看可以得知在spring-cloud-starter-gateway jar包中缺少LoadBalancerAutoConfigurationLoadBalancerClientFactory,所以GatewayReactiveLoadBalancerClientAutoConfiguration就不会被加载,更不会注入ReactiveLoadBalancerClientFilter bean。
所以spring-cloud-starter-gateway jar 包中只会有NoLoadBalancerClientFilter 不支持负载均衡。
所以问题就定位到了,是因为缺少LoadBalancerAutoConfiguration和LoadBalancerClientFactory 导致ReactiveLoadBalancerClientFilter 不能注入到容器中。所以只要将包含LoadBalancerClientFactory 的jar包添加到pom 文件中即可。
通过查询官网文档,得知使用负载均衡需要依赖

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-loadbalancer</artifactId>
        </dependency>

在这里插入图片描述
在这里插入图片描述

添加以上依赖,重新编译,启动程序,执行请求成功。完美解决问题!

参考资料

spring cloud 官网文档

总结:

通过查看spring-cloud-starter-gateway jar中的自动配置类的源码。得知,该jar包中是不支持负载均衡的,需要引入spring-cloud-starter-loadbalancer 来支持。

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要在Spring Cloud集成Nacos,需要添加以下依赖项: ``` <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> ``` 然后在`bootstrap.yml`或`bootstrap.properties`中配置以下内容: ``` spring.cloud.nacos.config.server-addr=${NACOS_SERVER_ADDR:localhost:8848} spring.cloud.nacos.config.namespace=${NACOS_NAMESPACE:} spring.cloud.nacos.config.group=${NACOS_GROUP:DEFAULT_GROUP} spring.cloud.nacos.config.prefix=${NACOS_CONFIG_PREFIX:} spring.cloud.nacos.config.file-extension=${NACOS_CONFIG_FILE_EXTENSION:properties} spring.cloud.nacos.config.shared-dataids=${NACOS_CONFIG_SHARED_DATAIDS:} spring.cloud.nacos.config.refreshable-dataids=${NACOS_CONFIG_REFRESHABLE_DATAIDS:} spring.cloud.nacos.discovery.server-addr=${NACOS_SERVER_ADDR:localhost:8848} spring.cloud.nacos.discovery.namespace=${NACOS_NAMESPACE:} spring.cloud.nacos.discovery.group=${NACOS_GROUP:DEFAULT_GROUP} ``` 其中,`NACOS_SERVER_ADDR`是Nacos Server的地址,`NACOS_NAMESPACE`是命名空间,`NACOS_GROUP`是配置和服务注册的分组,`NACOS_CONFIG_PREFIX`是前缀,`NACOS_CONFIG_FILE_EXTENSION`是配置文件后缀,`NACOS_CONFIG_SHARED_DATAIDS`是共享配置的dataids,`NACOS_CONFIG_REFRESHABLE_DATAIDS`是动态刷新的dataids。可以根据实际情况进行修改。 这样就完成了NacosSpring Cloud集成
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值