异步服务调用的工作原理

异步调用原理

1、消费者调用服务端发布的接口,接口调用由分布式服务框架包装成动态代理,发起远程服务调用;

2、通信框架异步发送请求消息,如果没有发生I/O异常,返回;

3、请求消息发送成功后,I/O线程构造Future对象,设置到RPC上下文中;

4、用户线程通过RPC上下文获取Future对象;

5、构造Listener对象,将其添加到Future中,用于服务端应答异步回调通知;

6、用户线程返回,不阻塞等待应答;

7、服务端返回应答消息,通信框架负责反序列化等;

8、I/O线程将应答设置到Future对象的操作结果中;

9、Future对象扫描注册的监听器列表,循环调用监听器的operationComplete方法,将结果通知给监听器,监听器获取到结果之后,继续后续业务逻辑的执行,异步服务调用结束。

10、参考资料链接:http://www.58maisui.com/2016/06/28/a-327/?ref=myread

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值