🎀Docker下Dubbo服务优雅上下线实现
简介
在Docker
容器环境中部署基于Dubbo
的服务时,实现服务的优雅上下线是至关重要的。这通常涉及到两个关键步骤:首先,确保服务能够从注册中心摘除,停止接受新的请求;其次,等待所有正在处理的请求完成后再终止容器。通过结合Kubernetes
的preStop Hook
和Dubbo
的QoS
功能,可以有效地实现这一目标。
环境
Docker
+ Kubernetes
+ SpringBoot
+ Dubbo
实现
PreStop Hook
Kubernetes
提供了生命周期钩子(Lifecycle Hooks
),其中preStop Hook
可以在容器被删除前触发,允许执行一些操作来准备容器的关闭。例如,可以配置preStop Hook
来调用Dubbo
的QoS
端点来通知服务下线:
preStop:
exec:
command: ["/bin/sh", "-c", "curl -X POST http://localhost:22222/offline && sleep 10"]
这里的命令会发送一个
HTTP
POST
请求到本地运行的Dubbo
QoS
服务,触发服务下线流程,并且等待 10 秒钟给服务足够的时间来完成正在进行中的请求。
Dubbo QoS
为了使用QoS
功能,需要确保Dubbo
应用程序已经正确配置并启用了QoS
。可以在 dubbo.properties
文件中添加以下配置:
dubbo.application.qos-enable=true
dubbo.application.qos-port=22222
QOS详细介绍可前往查看:dubbo QOS介绍及命令
解析
当容器接收到删除信号时,
preStop Hook
将被触发。它会先调用Dubbo
的QoS
/offline
端点来让服务实例从注册中心摘除,阻止新的请求被路由至此实例。随后,通过睡眠一段时间(例如上述例子中的 10 秒),给服务足够的时间来完成已接收的请求。在这之后,容器才会真正开始关闭进程。值得注意的是,在实际应用中,可能还需要考虑如何处理异常情况,比如网络延迟或
QoS
调用失败等问题。此时,可以通过设置合理的超时时间(TerminationGracePeriodSeconds
)来确保即使某些步骤未按预期完成,容器最终也能被安全地销毁。
综上所述,通过合理配置Kubernetes
的lifecycle hooks
和Dubbo
的QoS
功能,可以构建出一个健壮的服务框架,使得服务能够在不影响用户体验的情况下进行更新或维护。这种方法不仅提高了系统的可靠性,同时也简化了运维人员的操作复杂度。
结束
🎀Docker下Dubbo服务优雅上下线实现的更多相关文章
- Docker下dubbo开发三部曲之三:java开发
在前两章<Docker下dubbo开发,三部曲之一:极速体验>和<Docker下dubbo开发,三部曲之二:本地环境搭建>中,我们体验了dubbo环境搭建以及服务的发布和消费, ...
- Serverless 架构下的服务优雅下线实践
作者 | 行松 阿里巴巴云原生团队 应用发布.服务升级一直是一个让开发和运维同学既兴奋又担心的事情. 兴奋的是有新功能上线,自己的产品可以对用户提供更多的能力和价值:担心的是上线的过程会不会出现意外情 ...
- 如何在docker下安装elasticsearch(上)
一 环境 VMware® Workstation 15 Pro centos7 (1810) docker19.03.1 二 进入centos7启动dcoker systemctl start doc ...
- docker下部署服务
一.zabbix部署 需求: 因最近项目过多,人力监控耗费时间,打算部署一个zabbix,但又不想部署在宿主机上,就想起了docker,docker快速的移植性是最大的亮点,好了,言归正传开始干. 部 ...
- zookeeper 服务端上下线,客户端感知
package pfs.y2017.m11.zookeeper.demo03; import java.util.ArrayList; import java.util.List; import or ...
- springcloud优雅停止上下线与熔断
SpringCloud 服务优雅上下线 Spring Boot 框架使用"约定大于配置"的特性,优雅流畅的开发过程,应用部署启动方式也很优雅.但是我们通常使用的停止应用的方式是 k ...
- Spring Cloud Alibaba(四)实现Dubbo服务消费
本项目演示如何使用 Spring Cloud Alibaba 完成 Dubbo 的RPC调用. Spring Cloud与Dubbo Spring Cloud是一套完整的微服务架构方案 Dubbo是国 ...
- Dubbo学习笔记9:Dubbo服务提供方启动流程源码分析
首先我们通过一个时序图,直观看下Dubbo服务提供方启动的流程: 在<Dubbo整体框架分析>一文中我们提到,服务提供方需要使用ServiceConfig API发布服务,具体是调用代码( ...
- (转)淘淘商城系列——引用dubbo服务
http://blog.csdn.net/yerenyuan_pku/article/details/72758663 上文我们一起学习了如何发布一个dubbo服务,本文我就来教大家如何在web工程中 ...
- docker下tomcat连redis
之前已经讲了然后通过Maven 项目管理工具创建Web项目, 最后打包成War包 讲了docker 配置 Tomcat , Redis 现在讲如何使用War包,以及在docker下, 让jsp连上re ...
随机推荐
- .NET 中 Logger 常被忽视的方法 BeginScope
BeginScope 方法是 .NET 中 ILogger 接口的一部分,用于创建日志记录的作用域(Scope).这种作用域可以将特定的上下文信息包含在日志中,从而提高日志的可读性和调试效率. 配置日 ...
- google gtest框架入门使用案例
通过本文可以收获:google gtest急速入门.google gtest资源网站. google gtest是什么 google gtest是谷歌开源的c++单元测试框架,非常的好用. 起码个人感 ...
- dart子类的继承
1 Dart中类的继承 1.子类使用extends关键字来继承父类 2.子类会继承父类里面可见的属性和方法,但是不会继承构造函数 3. 子类能够复写父类的方法 getter和setter方法 2Dar ...
- .Net Core报“‘GB2312‘ is not a supported encoding name. For information on defining a custom encod”的错误
1.问题描述 在.Net Core中使用Encoding.GetEncoding("GB2312")报如下错误: System.ArgumentException:"'G ...
- 快速 log2 取整算法 (O(1) 时间与空间复杂度)
先上核心代码(文末附针对多种整数类型的代码): inline int log_2(int x) { int rst = 0; if (x & 0xffff'0000U) rst += 16, ...
- pkill 踢出某个终端
是ps命令和kill命令的结合,按照进程名来杀死指定进程 选项 -o:仅向找到的最小(起始)进程号发送信号: -n:仅向找到的最大(结束)进程号发送信号: -P:指定父进程号发送信号: -g:指定进程 ...
- 任务调度器Azkaban(Azkaban环境部署)
文章链接:https://www.cnblogs.com/liugp/p/16273966.html
- FLink自定义Kafka Source,处理后转发给下一个kafka topic
一.依赖配置 pom文件:https://www.cnblogs.com/robots2/p/16048648.html kafka单机版安装:https://www.cnblogs.com/robo ...
- Vue3 基础概念与环境搭建
前言 首先需要提醒大家的是,Vue2 已经在2023年停止维护,为了能更好地适应前端开发的发展趋势以及获得更好的性能和功能,我们将从这篇文章开始进入Vue3的阶段.如果对Vue2有想了解的小伙伴可以自 ...
- ABB喷涂机器人IRB5400维修保养
为最大限度地保证ABB机器人正常运行,ABB机器人普遍需要在运行6000小时后进行一次保养,特别是针对在恶劣工况与长时间在负载极限或运行极限下工作的ABB机器人,则需要每年进行一次全面ABB机器人保养 ...