博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ForkJoin框架简单使用
阅读量:755 次
发布时间:2019-03-23

本文共 568 字,大约阅读时间需要 1 分钟。

场景描述

设想这样一个场景,在一个接口中,需要通过http的方式调用多个外部接口,而且可能存在某几个接口非常耗时的情况,这么一来,对当前接口来说,由于是串行的执行,忽略本地接口的耗时,总的耗时就可以大致估算为调用的多个外部接口响应时间之和,这还是在没有考虑网络延时等其他外部因素作用下

这种场景在业务中随处可见,也是程序员考虑的优化接口响应时间的入手点

解决思路

当存在上述的情况,我们很自然的联想到能否采用多线程的方式,将不同的http接口调用放到不同的线程中执行,最后再拿到各自的执行结果呢?这里有两种情况需要考虑

1. 各个http接口的调用结果是否有业务上的关联性

2. 使用哪种方式合并各自接口的返回结果

第一点是非常关键的,也是能否考虑使用多线程优化的重要一点,假设各个接口具备前后业务上的逻辑关系,第二个调用的接口的参数来自于第一个接口的返回结果,这个显然不行

假如不存在业务上的关联性,就可以考虑使用多线程的方式进行优化,但实现方式也是有很多种,具体使用哪种呢?下面介绍几种方式

问题复现

在当前的一个接口中,需要分别调用另外两个服务的接口,然后在本地接口中进行数据集合并

@Servicepublic class UserService {   
@Autowired private RestTem

转载地址:http://giozk.baihongyu.com/

你可能感兴趣的文章