解决springcloud集成nacos遇到的问题

 更新时间:2023年04月10日 09:52:29   作者:wyz0923  
这篇文章介绍了如何解决springcloud集成nacos遇到的问题,文章中有详细的代码示例,需要的朋友可以参考一下

背景

最近在搭建微服务框架,在搭建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 文件并打开,发现跟负载均衡有关系的配置类有GatewayNoLoadBalancerClientAutoConfiguration和GatewayReactiveLoadBalancerClientAutoConfiguration
这两个配置类。根据名称可以知道
GatewayNoLoadBalancerClientAutoConfiguration 是不支持负载均衡客户端的自动配置类。
而GatewayReactiveLoadBalancerClientAutoConfiguration 是支持负载均衡客户端配置类。

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

GatewayNoLoadBalancerClientAutoConfiguration 代码如下

可以看出这个配置类就干了一个事,向容器中注入一个NoLoadBalancerClientFilter过滤器。该过滤器的过滤方法就是当发现url 中配置的是lb 约束 时抛出NotFoundException异常。
查看创建异常方法

以为with404 这个参数从配置文件中配置的,默认值是false。所以该方法会抛出503异常。

GatewayReactiveLoadBalancerClientAutoConfiguration代码如下

查看可以得知在spring-cloud-starter-gateway jar包中缺少LoadBalancerAutoConfiguration和LoadBalancerClientFactory,所以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-starter-gateway jar中的自动配置类的源码。得知,该jar包中是不支持负载均衡的,需要引入spring-cloud-starter-loadbalancer 来支持。

到此这篇关于解决springcloud集成nacos遇到的问题的文章就介绍到这了,更多相关springcloud集成nacos问题内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 在springboot中使用AOP进行全局日志记录

    在springboot中使用AOP进行全局日志记录

    这篇文章主要介绍就在springboot中使用AOP进行全局日志记录,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • 详谈cxf和axis两种框架下的webservice客户端开发

    详谈cxf和axis两种框架下的webservice客户端开发

    这篇文章主要介绍了详谈cxf和axis两种框架下的webservice客户端开发,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • Java的ConcurrentLinkedQueue源码分析

    Java的ConcurrentLinkedQueue源码分析

    这篇文章主要介绍了Java的ConcurrentLinkedQueue源码分析,ConcurrentLinkedQueue 是一个基于链接节点的无界线程安全的队列,当我们添加一个元素的时候,它会添加到队列的尾部,当我们获取一个元素时,它会返回队列头部的元素,需要的朋友可以参考下
    2023-12-12
  • Mock和@InjectMocks的区别及说明

    Mock和@InjectMocks的区别及说明

    @Mock和@InjectMocks是Mockito框架中的两个注解,前者用于创建模拟对象,后者用于将模拟对象注入到被测试类中
    2024-11-11
  • JAVA字符串格式化-String.format()的使用

    JAVA字符串格式化-String.format()的使用

    本篇文章主要介绍了JAVA字符串格式化-String.format()的使用,具有一定的参考价值,有需要的可以了解一下。
    2016-11-11
  • Maven使用集成测试的示例代码

    Maven使用集成测试的示例代码

    本文介绍了在Maven项目中使用maven-failsafe-plugin插件进行集成测试,步骤包括添加测试依赖、编写集成测试类、配置插件、运行测试以及查看和分析测试结果,感兴趣的可以了解一下
    2024-11-11
  • Java 限制前端重复请求的实例代码

    Java 限制前端重复请求的实例代码

    这篇文章主要介绍了Java 限制前端重复请求,文中给大家提到了JAVA利用自定义本地锁解决重复提交的问题,通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • Java中classpath讲解及使用方式

    Java中classpath讲解及使用方式

    本文详细讲解了Java中classpath讲解及使用方式,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • linux用java -jar启动jar包缓慢的问题

    linux用java -jar启动jar包缓慢的问题

    这篇文章主要介绍了linux用java -jar启动jar包缓慢的问题,具有很好的参考价值,希望对大家有所帮助,
    2023-09-09
  • Mybatis Plus 实现批量插入的示例代码

    Mybatis Plus 实现批量插入的示例代码

    本文主要介绍了Mybatis Plus 实现批量插入的示例代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09

最新评论