在耗时较长的Controller中使用Future异步

有一些Controller要算一些东西,可能会耗时较长,我们以休眠2秒来模拟这个过程。

代码如下

public class Dog implements Serializable {
    private String name;
    private int age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}
@RestController
public class DogController {
    @GetMapping("/getdog")
    public Dog getDog() throws InterruptedException {
        Dog dog = new Dog();
        dog.setName("mimi");
        dog.setAge(1);
        Thread.sleep(2000);
        return dog;
    }
    @GetMapping("/syncgetdog")
    public Callable<Dog> syncGetDog() {
        Callable<Dog> dog = new Callable<Dog>() {
            @Override
            public Dog call() throws Exception {
                Dog midog = new Dog();
                midog.setName("mimi");
                midog.setAge(1);
                Thread.sleep(2000);
                return midog;
            }
        };
        return dog;
    }
}

这里我们使用了两种方式来获取一条狗的名字和年龄。第一种是最传统的单线程返回。第二种采用了Future模式的异步返回。我们对性能进行一次压测,压测的线程数1000,循环5次,共5000次。

5d0d7f22a8690e826171d0f3f8d6bc3a9b7.jpg

我们先来压第一个getdog

763579c938ea6762ff02ea7cf8db8ae334a.jpg

压测结果如下

1f47c85c7265fdfcc390048ffe1a5c31b7f.jpg

通过该结果我们可以看到吞吐量为96.9,最小响应时间2秒6,最大响应时间10秒3(当然这是我本机的压测,非服务器,数值量会偏小)

然后我们对异步调用进行压测

4759637f79218786fc3d7c27b86da5c4c16.jpg

压测结果如下

7441903d6e316df2f7aee02609c5a0ef49b.jpg

吞吐量379.2,最小响应时间2秒,最大响应时间3秒。

原因主要在于单线程的程序一条道走到黑,不运行完绝不撒手,Tomcat的可用线程被完全霸占。而Future模式的异步调用则是另外启动一个线程将Callable交给TaskExecutor去处理,Tomcat自己的主线程退出,去重新接收其他的请求调用,等到Callable执行结束后,就会重新启动分配一个request请求,调用和处理Callable异步执行的返回结果,然后最终返回结果。

但这里有一点需要说明,当一个请求处理及其短时间的时候,不要使用Future模式的异步调用,性能反而不如单线程模式。

转载于:https://my.oschina.net/u/3768341/blog/2575151

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值