dubbo优雅停机时做了什么,会不会等待消费方调用完成

模拟了消费方正在调用,服务端停机过程。
通过查看服务端和消费方打印出的log日志,得出双方关闭的进行的操作。


服务端

1、从zookeeper移除注册的服务
Close all registries、Destroy registry、Unregister、Unsubscribe


2、关闭spring容器
   调用了spring的ClassPathXmlApplicationContext.stop,close方法
   rabbit Mq在同一线程内也打印了一段log,Waiting for workers to finish,等待工作的线程完成
   数据源也关闭掉了, {dataSource-3} closed


3、关闭ZkClient
   Closing ZkClient


4、关闭dubbo服务和netty
   Close dubbo server,Close NettyServer bind


5、关闭到其他服务的连接,以及rpc引用
   Close dubbo connect,Close netty channel,Destroy reference


6、关闭暴露的服务
   Unexport service


7、断开虚拟机




正在调用的消费方:
1、接收到来自zookeeper服务下线的事件
    对应服务端的第一条


2、关闭正在调用该服务的通道
   Close netty channel,disconected from服务端口


3、超时抛出异常
   超时应该有专门的线程存活监听


4、摧毁下线服务的消费方
    Destroy unregister url consumer


5、关闭zookeeper
   Closing ZooKeeper


6、关闭到其他服务的连接
 Close dubbo connect


得出结论:

服务方不会等待正在调用的消费方完成再去关闭服务。即服务端程序可能正在执行到某一行而突然结束,消费方的调用程序会抛出超时异常。



  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值