原创

Dubbo 源码解析 ------ 优雅停机

本文基于 Dubbo 2.6.1 版本,望知悉。

参考文章

《Dubbo 用户指南 —— 优雅停机》

定义如下:
Dubbo 是通过 JDK 的 ShutdownHook 来完成优雅停机的,所以如果用户使用 kill -9 PID 等强制关闭指令,是不会执行优雅停机的,只有通过 kill PID 时,才会执行。

原理如下:

服务提供方

  • 停止时,先标记为不接收新请求,新请求过来时直接报错,让客户端重试其它机器。 //<1>
  • 然后,检测线程池中的线程是否正在运行,如果有,等待所有线程执行完成,除非超时,则强制关闭。 // <2>

服务消费方

  • 停止时,不再发起新的调用请求,所有新的调用在客户端即报错。 // <3>
  • 然后,检测有没有请求的响应还没有返回,等待响应返回,除非超时,则强制关闭。 // <4>
正文到此结束
广告是为了更好的提供数据服务
本文目录