zoukankan      html  css  js  c++  java
  • 优雅停机

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

    原理

    服务提供方

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

    服务消费方

    • 停止时,不再发起新的调用请求,所有新的调用在客户端即报错。
    • 然后,检测有没有请求的响应还没有返回,等待响应返回,除非超时,则强制关闭。

    设置方式

    设置优雅停机超时时间,缺省超时时间是 10 秒,如果超时则强制关闭。

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

    如果 ShutdownHook 不能生效,可以自行调用,使用tomcat等容器部署的場景,建议通过扩展ContextListener等自行调用以下代码实现优雅停机

    ProtocolConfig.destroyAll();

  • 相关阅读:
    020606-04-聊天布局-键盘处理
    020606-03-聊天布局-键盘处理
    02060601-聊天布局
    按钮背景图片拉伸
    源码-0205-02--聊天布局02
    源码-0205-02--聊天布局
    向量投影公式
    定比分点、中点公式
    重叠检测----凸边形
    aabb碰撞检测
  • 原文地址:https://www.cnblogs.com/yifanSJ/p/9199758.html
Copyright © 2011-2022 走看看