dubbo使用异步方式调用对象
来源:互联网 发布:淘宝客api怎么用 编辑:程序博客网 时间:2024/05/16 10:41
相对比与前一个小节来说,异步调用的功能也是很实用的,现在异步化的操作是越来越多了,异步化的好处也是比较明显的,可以加快后台的处理效率,做到代码直接的解耦,Dubbo就是一个支持异步调用的RPC框架
3.2.1 异步调用的场景
假设系统A,远程调用B系统的某个方法,这个方法与数据库的交互很多,逻辑相对复杂,正常的代码执行的时间是3秒,A系统调用完B系统之后,还需要做一些其他的逻辑操作,这个代码耗时可能需要4秒,等这个3秒的逻辑做完之后,根据B系统返回的结果再做一些其他的操作,那么同步调用的时间是3秒+4秒 = 7秒,那么一次操作的时间就是7秒
异步访问B系统:
3.2.2 同步调用的实现:
接口实现(provider和consumer端都需要)
接口实现,我们默认线程sleep三秒,3秒代表代码复杂的逻辑操作和数据库的交互的时间
在不开启异步调用的配置的时候,spring的配置文件和普通配置是一样的spring-dubbo-provider-async.xml,需要注意的是我们线程故意睡了3秒,这边我们配置timeout的时间为4秒,否则就会调用超时:
消费端的spring配置文件spring-dubbo-consumer-async.xml:服务提供者端的测试类:
服务消费者端的测试类:
先启动DubboxProviderAsyncService,然后再启动DubboConsumerAsyncService的main函数:
消费端的控制台打印信息是:
运行没有问题,但是调用10次,一共耗时71秒,假如改成异步调用,我们不需要等待调用返回的结果,而是在用的时候,再去获取值的话,这样会大大的提高执行的速度
3.2.3异步调用实现
异步调用的实现,很简单,现在我们修改一下配置文件,使其支持异步调用,其实配置相对比较简单,只需要在调用端的spring的配置文件中加上async=”true”,注意一定是在调用端配置该关键字,异步调用,顾名思义,就是需要告之调用者,调用之后不需要等待(Note:修改的是调用的spring配置文件spring-dubbo-consumer-async.xml)
其实就是加了一个标签的支持,async="true",这样就支持了异步的调用了修改消费者的测试代码,配置文件的修改只是告诉Dubbo,调用者会进行异步调用,但如何异步调用,还是需要调用者自己去实现的,实现依赖于RpcContext:
关键代码就是:
这行代码不会阻塞至服务提供者端把数据返回,而是直接返回,然后睡了4秒,这个4秒,模仿的是本地的逻辑操作,这是其实远程的逻辑也在执行,这样就可以并行操作了,最后调用:获取到远程调用异步返回的结果,完成最后的操作,我们可以看啊看控制台打印的结果:可以看出结果没有变,仍旧是3,但是调用时间变成了41秒,异步调用的好处就可以显示出来了
3.2.4本章小结
异步调用是一个很实用的功能,在一些特定的开发业务场景下,能发挥很大的作用,Dubbo对异步调用支持的比较完善,并且方便开发人员适用,需要一个简单的标签就可以完成该功能了,方便大家的对该功能的掌握。
- dubbo使用异步方式调用对象
- dubbo异步调用三种方式
- dubbo异步同步调用混合使用问题
- dubbo 使用学习八(异步调用)
- dubbo 使用学习八(异步调用
- Dubbo异步调用
- Dubbo-----异步调用
- dubbo异步调用
- 使用异步方式调用WebService
- Dubbo学习(十):异步调用
- Dubbo异步方法调用里有个坑
- dubbo异步调用的bug
- 使用异步方式调用同步方法
- 使用异步方式调用同步方法
- 使用异步方式调用同步方法
- 使用异步方式调用同步方法
- 服务端调用dubbo的方式
- 服务端调用dubbo的方式
- android 高德地图
- C/C++ OpenCV设置感兴趣区域ROI
- mysql索引总结----mysql 索引类型以及创建
- iFunk:最美的风景只在走过的路上
- 一个函数有多少行代码比较合适?
- dubbo使用异步方式调用对象
- python常见错误集合
- 3D数学 学习笔记(1) 向量、坐标系
- Android开发短信相关的知识
- Atcoder CODE FESTIVAL 2017 qual C 总结+ABCD题解
- diff: /../Podfile.lock: No such file or directory diff: /Manifest.lock: No such file or directory er
- TCP三次握手四次断开
- 随机森林进行特征重要性度量的详细说明
- java中的接口