zoukankan      html  css  js  c++  java
  • Dubbo优雅关机原理

    Dubbo是通过JDK的ShutdownHook来完成优雅停机的

    所以如果用户使用 kill -9 PID 等强制关闭命令,是不会执行优雅停机的

    只有通过 kill PID时,才会执行

    原理:

           · 服务提供方

          · 停止时,先标记为不接收新请求,新请求过来时直接报错,让客户端重试其他机器。

          · 然后,检测线程池中的线程是否正在运行,如果有,等待所有线程执行完成,除非超时,则强制关闭。

           · 服务消费方

          · 停止时,不在发起新的调用请求,所有新的调用在客户端即报错。

          · 然后,检测有没有请求的响应还没有返回,等待响应返回,除非超时,则强制关闭。

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

    <dubbo:application ...>

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

    </dubbo:application>

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

      ProtocolConfig.destroyAll();

  • 相关阅读:
    让你少奋斗10年的工作经验
    POJ Exponentiation解题
    数据结构树和二叉树
    语句摘录
    ACM解题报告格式
    编程规范
    数据结构图
    Java学习之二Java反射机制
    使用Python正则表达式提取搜索结果中的站点
    toj 1702 A Knight's Journey
  • 原文地址:https://www.cnblogs.com/wangfajun/p/5274675.html
Copyright © 2011-2022 走看看