本文共 568 字,大约阅读时间需要 1 分钟。
设想这样一个场景,在一个接口中,需要通过http的方式调用多个外部接口,而且可能存在某几个接口非常耗时的情况,这么一来,对当前接口来说,由于是串行的执行,忽略本地接口的耗时,总的耗时就可以大致估算为调用的多个外部接口响应时间之和,这还是在没有考虑网络延时等其他外部因素作用下
这种场景在业务中随处可见,也是程序员考虑的优化接口响应时间的入手点
当存在上述的情况,我们很自然的联想到能否采用多线程的方式,将不同的http接口调用放到不同的线程中执行,最后再拿到各自的执行结果呢?这里有两种情况需要考虑
1. 各个http接口的调用结果是否有业务上的关联性
2. 使用哪种方式合并各自接口的返回结果第一点是非常关键的,也是能否考虑使用多线程优化的重要一点,假设各个接口具备前后业务上的逻辑关系,第二个调用的接口的参数来自于第一个接口的返回结果,这个显然不行
假如不存在业务上的关联性,就可以考虑使用多线程的方式进行优化,但实现方式也是有很多种,具体使用哪种呢?下面介绍几种方式
在当前的一个接口中,需要分别调用另外两个服务的接口,然后在本地接口中进行数据集合并
@Servicepublic class UserService { @Autowired private RestTem
转载地址:http://giozk.baihongyu.com/