我是靠谱客的博主 超帅胡萝卜,最近开发中收集的这篇文章主要介绍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();

最后

以上就是超帅胡萝卜为你收集整理的dubbo优雅停机的全部内容,希望文章能够帮你解决dubbo优雅停机所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部