kill -9 PID 强制关闭造成 dubbo消费方无法消费

我们在dubbo时,我们项目由dubbo的版本由2.7.0升级到2.7.5。出现了dubbo无效消费的情况,经过检查发现zookeeper 里面出现大量相同的注册信息。dubbo是通过JDK的ShutdownHook来完成优雅停机的,所以如果我们使用”kill -9 PID”等强制关闭指令,是不会执行优雅停机的,只有通过”kill PID”时,才会执行。服务强制停止造成大量相同注册信息积压在zookeeper中。

当dubbo执行优雅停机时:

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

服务消费方:
停止时,不在发起新的调用请求,所有新的调用在客户端即报错;
然后,检测有没有请求的相应还没有返回,等待相应返回,,除非超时,则强制关闭;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章