开发者社区 > 云原生 > 正文

下线或者关停服务,gateway的负载还是会分到已经关掉的服务里

网上有说是ribbon的定时任务更新可用服务列表导致的,无法及时更新可用服务, 这个是否有解决办法,

现在导致的问题是 无法无缝更新,需要去/actuator/service-registry?status=DOWN 接口先注销掉服务才能优雅关停服务 类似eureka(请求注销+sleep) 无法使用nacos的秒级切换上下线 ,正常关停服务也是,是否nacos支付其他方式 来优雅关停服务

原提问者GitHub用户jackfruitran

展开
收起
白夜行fighting 2023-06-11 10:11:58 102 0
1 条回答
写回答
取消 提交回答
  • Ribbon 有个刷新时间,默认是 30s。会调用 ServerList#getUpdatedListOfServers 方法获取实例,可以通过 ribbon.ServerListRefreshInterval=ms 配置刷新时间

    服务下线前调用 /actuator/service-registry?status=DOWN 先下线实例,然后等待下一次服务实例的刷新确保不会拿到下线的实例 参考 Spring Cloud 应用优雅下线

    原回答者GitHub用户fangjian0423

    2023-06-11 11:16:51
    赞同 展开评论 打赏
问答分类:
问答地址:

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载