dubbo注销流程

服务端

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

得出结论:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值