微服务滚动法布

滚动发布:1.启动新的服务并进行健康检查------2.新服务启动------3.杀老服务-----4.发送curl到nacos下线---5.等待10S-------6.杀老服务

在Nacos中,服务实例的上下线状态是由服务实例自身通过心跳机制与Nacos服务器交互来维持和控制的。当服务实例启动时,它们会向Nacos注册,并开始定期发送心跳(默认每隔5秒一次)来表明自己的在线状态。如果Nacos服务器在一段时间内(默认15秒)没有收到服务实例的心跳,则会认为该实例处于不健康状态,并在后续一段时间(默认30秒)后将其从服务列表中移除,即视为下线。

当你在Nacos控制台上手动将一个服务实例标记为下线时,实际上是Nacos服务器收到了下线指令并将实例状态更新为下线。然而,如果你随后重新发布服务(比如重启服务实例),而服务实例在启动时仍然按照常规流程向Nacos注册并发送心跳,那么服务实例就会再次显示为上线状态。

出现有时点击下线后,再次发布服务实例又变为上线状态的情况,原因可能包括:

服务实例未正确处理下线逻辑:服务实例在接收到下线信号后,如果没有立即停止向Nacos发送心跳或者没有在启动时检查自己是否应该保持下线状态,那么一旦服务重新启动,它会像正常情况一样注册并向Nacos报告心跳,从而导致它看上去又上线了。

下线操作未持久化:如果服务实例的下线状态没有被持久化存储,或者存储的状态没有在实例重新启动时被读取并应用,那么服务实例会忘记自己先前被下线的事实。

网络延迟或故障:在某些情况下,由于网络问题,下线指令可能并未成功到达服务实例,或者实例下线后Nacos服务器未能及时感知到实例心跳停止,进而造成实例重新上线的现象。

为了确保服务实例能够准确地响应下线操作并在重新发布时不自动上线,应当确保服务实例在启动时检查自身是否应该处于下线状态,如果是,则不应继续向Nacos注册和发送心跳。此外,也可以考虑结合服务治理框架或服务部署脚本,在下线后采取更严格的控制措施,例如暂停服务进程、调整负载均衡策略等。

相关推荐
文火冰糖的硅基工坊4 分钟前
[硬件电路-97]:模拟器件 - 如何通过外部的闭环负反馈,让运算放大器从“暴脾气”、“愣头青”、情绪容易失控者变成“沉着”、“冷静”的精密调控者的?
嵌入式硬件·架构·电路·跨学科融合
东风微鸣4 分钟前
提升效率:AI 知识库在软件开发中的应用
docker·云原生·kubernetes·可观察性
Lyndon11075 分钟前
K8S 八 数据存储-高级存储PV PVC 生命周期;配置存储ConfigMap Secret
云原生·容器·kubernetes
●VON37 分钟前
重生之我在暑假学习微服务第二天《MybatisPlus-下篇》
java·学习·微服务·架构·mybatis-plus
秋千码途1 小时前
小架构step系列27:Hibernate提供的validator
java·spring·架构·hibernate
Hermann2 小时前
云原生系统健壮性浅谈
架构·云计算
白-胖-子8 小时前
深入剖析大模型在文本生成式 AI 产品架构中的核心地位
人工智能·架构
武子康8 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
Pomelo_刘金11 小时前
用 DDD 把「闹钟」需求一点点捏出来
架构·rust·领域驱动设计
Pomelo_刘金12 小时前
Clean Architecture 整洁架构:借一只闹钟讲明白「整洁架构」的来龙去脉
后端·架构·rust