前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Gateway+Nacos根据服务名称实现动态路由报错:type=Service Unavailable, status=503

Gateway+Nacos根据服务名称实现动态路由报错:type=Service Unavailable, status=503

作者头像
灰小猿
发布2023-04-06 11:11:44
8390
发布2023-04-06 11:11:44
举报

hello,你好呀,我是灰小猿,一个超会写bug的程序猿!

最近在开发SpringCloud Alibaba相关的项目的时候遇到了一个比较容易踩的坑,在这里记录一下,与大家共勉。

场景是这样的:当时我要以Ncaos作为注册中心,在多服务的情况的下,使用Gateway通过服务名称来实现动态路由,但是当我通过服务名称进行请求时,一直提示“type=Service Unavailable, status=503”,但是检查yml配置和路由设置都没有问题,这就很疑惑???

我的使用场景:

  • SpringBoot版本为2.6.0
  • Spring Cloud版本为2021.0.1
  • Spring Cloud Alibaba版本为2021.0.1.0

Gateway服务中的yml文件:

代码语言:javascript
复制
#如下配置一定要注意空格和yml格式正确
server:
  port: 80
spring:
  application:
    name: gateway-server
  cloud:
    #注册到nacos
    nacos:
      server-addr: localhost:8848
      username: nacos
      password: nacos
    #网关设置
    gateway:
      discovery:
        locator:
          enabled: true #开启动态路由
          lower-case-service-id: true
      enabled: true # =只要加了依赖 默认开启
      routes:
        - id: login-service-route  # 这个是路由的id 保持唯一即可
          uri: http://localhost:8081   
          predicates: # 断言是给某一个路由来设定的一种匹配规则 默认不能作用在动态路由上
            - Path=/doLogin  # 匹配规则  只要你Path匹配上了/doLogin 就往 uri 转发 并且将路径带上
        - id: teacher-service-route
          uri: lb://teacher-service
          predicates:
            - Path=/**

并且Gateway和每一个服务都通过@EnableDiscoveryClient注解加入到了Nacos中,且在Nacos中可以看到。

由于我在Gateway服务中设置了过滤器,所以通过过滤器断点发现通过服务名称来进行路由时,请求进入了过滤器并且被放行,说明请求本身没有问题,但是就是请求不到对应的接口,

经过在网上找了资料发现是由于版本问题:

原因:由于springcloud从2020版本开始弃用了Ribbon,所以Alibaba在2020及之后版本的nacos中删除了Ribbon的jar包, 因此无法通过lb路由到指定微服务,所以导致出现了503情况。

从上面的配置中可以看出在实现动态路由时,Uri我使用了lb的形式,在结合上面说到的版本变更,问题原因就找到,原来Ribbon实现负载均衡的功能不能再使用了,就需要引入新的依赖。

解决方案 :只需要引入springcloud loadbalancer包即可!并且注意该依赖是需要添加在Gateway所在的服务下的,服务提供者不需要添加(亲测)

代码语言:javascript
复制
<!--客户端负载均衡loadbalancer-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

加入如上依赖后,重新运行网关服务并重新尝试请求,测试成功!

最后提醒一下大家,开发中如果使用的是SpringCloud Alibaba 2020.0.1.0及其之后的版本,发现异常时可以优先考虑下是否是版本存在变更或需要兼容的地方!

我是灰小猿,我们下期见!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-04-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
负载均衡
负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档