dubbo优雅停机

dubbo优雅停机

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


原理

  • 服务提供方
    • 停止时,先标记为不接受新的请求,新请求过来时直接报错,让客户端重试其他机器;
    • 然后,检测线程池中的线程是否正在运行,如果有,等待所有线程执行完成,除非超时,则强制关闭;
  • 服务消费方
    • 停止时,不在发起新的调用请求,所有新的调用在客户端即报错;
    • 然后,检测有没有请求的相应还没有返回,等待相应返回,,除非超时,则强制关闭;

设置优雅停机超时时间,缺省超时时间是10秒;(超时则强制关闭)

<dubbo:application ...>
    <dubbo:parameter key="shutdown.timeout" value="60000" /><!-- 单位毫秒 -->
</dubbo:application>

如果ShutdownHock不能生效,可以自行调用:

ProtocolConfig.destoryAll();
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值