Spring Boot 揭秘与实战(七) 实用技术篇 - 异步任务
拓展阅读: http://www.jianshu.com/p/86e915d616c4

发表于 2017-01-06 | Spring框架 | SpringBoot

Spring 对异步任务具有很好的支持。这篇文章,我们透过 Spring Boot 来讲解下单发服务模式和请求应答模式。

Spring Boot 集成异步任务

在 Spring Boot 中使用 @EnableAsync 开启异步支持。

    1. @Configuration
    1. @EnableAsync
    1. public class AsyncConfig {
    1. }

现在,我们在 Spring Boot 中,我们只需要通过使用 @Async 注解就能将原来的同步方法变为异步方法。

单发服务模式

多个服务之间逻辑上不存在相互依赖关系,执行先后顺序没有严格的要求,逻辑上可以被并行执行。对于单发服务只有请求,没有应答,很容易设计成异步的。发起服务调用后。立即返回,不需要同步阻塞等待应答。

    1. @Service
    1. public class MsgServer {
    1. @Async
    1. public void sendA() throws Exception {
    1. System.out.println("send A");
    1. Long startTime = System.currentTimeMillis();
    1. Thread.sleep(2000);
    1. Long endTime = System.currentTimeMillis();
    1. System.out.println("耗时:" + (endTime - startTime));
    1. }
    1. @Async
    1. public void sendB() throws Exception {
    1. System.out.println("send B");
    1. Long startTime = System.currentTimeMillis();
    1. Thread.sleep(2000);
    1. Long endTime = System.currentTimeMillis();
    1. System.out.println("耗时:" + (endTime - startTime));
    1. }
    1. }

此时,因为我们添加了 @Async 注解,它就变成了异步方法。

    1. @RunWith(SpringJUnit4ClassRunner.class)
    1. @SpringApplicationConfiguration(classes = WebMain.class)
    1. public class AsyncTest {
    1. @Autowired
    1. private MsgServer msgServer;
    1. @Test
    1. public void test() throws Exception {
    1. msgServer.sendA();
    1. msgServer.sendB();
    1. }
    1. }

请求应答模式

对于,请求的内容,需要应答,例如我们需要在多个方法调用都完成后,才进行接下来的操作,此时我们可以利用 Java 的 Future-Listener 机制来实现异步服务调用。

    1. @Service
    1. public class MsgFutureServer {
    1. public static Random random = new Random();
    1. @Async
    1. public Future<String> sendA() throws Exception {
    1. System.out.println("send A");
    1. Long startTime = System.currentTimeMillis();
    1. Thread.sleep(2000);
    1. Long endTime = System.currentTimeMillis();
    1. System.out.println("耗时:" + (endTime - startTime));
    1. return new AsyncResult<String>("success");
    1. }
    1. @Async
    1. public Future<String> sendB() throws Exception {
    1. System.out.println("send B");
    1. Long startTime = System.currentTimeMillis();
    1. Thread.sleep(2000);
    1. Long endTime = System.currentTimeMillis();
    1. System.out.println("耗时:" + (endTime - startTime));
    1. return new AsyncResult<String>("success");
    1. }
    1. }

下面的单元测试,在等待完成两个异步任务后,再统计具体耗时时长。

    1. @RunWith(SpringJUnit4ClassRunner.class)
    1. @SpringApplicationConfiguration(classes = WebMain.class)
    1. public class AsyncFutureTest {
    1. @Autowired
    1. private MsgFutureServer msgFutureServer;
    1. @Test
    1. public void test() throws Exception {
    1. long startTime = System.currentTimeMillis();
    1. Future<String> task1 = msgFutureServer.sendA();
    1. Future<String> task2 = msgFutureServer.sendB();
    1. while(true) {
    1. if(task1.isDone() && task2.isDone() ) {
    1. break;
    1. }
    1. }
    1. long endTime = System.currentTimeMillis();
    1. System.out.println("总耗时:" + (endTime - startTime));
    1. }
    1. }

源代码

相关示例完整代码: springboot-action

springboot 异步任务的更多相关文章

  1. 新手也能看懂的 SpringBoot 异步编程指南

    本文已经收录自 springboot-guide : https://github.com/Snailclimb/springboot-guide (Spring Boot 核心知识点整理. 基于 S ...

  2. springboot异步线程(二)

    前言 本篇文章针对上篇文章springboot异步线程,有一位大佬在评论中提出第一点是错误的,当时看到了这个问题,最近刚好有空,针对第一点的问题去搜索了不少的文章: 问题 我在文章中第一点去验证:Sc ...

  3. springboot异步线程

    前言 最近项目中出现了一个问题,发现自己的定时器任务在线上没有执行,但是在线下测试时却能执行,最后谷歌到了这篇文章SpringBoot踩坑日记-定时任务不定时了?; 本篇文章主要以自己在项目中遇到的问 ...

  4. SpringBoot异步编程

    异步调用:当我们执行一个方法时,假如这个方法中有多个耗时的任务需要同时去做,而且又不着急等待这个结果时可以让客户端立即返回然后,后台慢慢去计算任务.当然你也可以选择等这些任务都执行完了,再返回给客户端 ...

  5. SpringBoot学习笔记(七):SpringBoot使用AOP统一处理请求日志、SpringBoot定时任务@Scheduled、SpringBoot异步调用Async、自定义参数

    SpringBoot使用AOP统一处理请求日志 这里就提到了我们Spring当中的AOP,也就是面向切面编程,今天我们使用AOP去对我们的所有请求进行一个统一处理.首先在pom.xml中引入我们需要的 ...

  6. SpringBoot 异步 定时任务 邮件

    springboot异步 一: 在 MyConfiguration.java 中开启注解 @Configuration//指明当前类是一个配置类:就是来替代之前的Spring配置文件@EnableAs ...

  7. 带着新人学springboot的应用09(springboot+异步任务)

    本来想说说检索的,不过不知道什么鬼,下载ElasticSearch太慢了,还是放一下,后面有机会再补上!今天就说个简单的东西,来说说任务. 什么叫做任务呢?其实就是类中实现了一个什么功能的方法.常见的 ...

  8. springboot 异步调用Async使用方法

    引言: 在Java应用中,绝大多数情况下都是通过同步的方式来实现交互处理的:但是在处理与第三方系统交互的时候,容易造成响应迟缓的情况,之前大部分都是使用多线程来完成此类任务,其实,在spring 3. ...

  9. SpringBoot 异步输出 Logback 日志

    一.介绍 1.1 Logback Logback是由log4j创始人设计的另一个开源日志组件,它分为下面下个模块: logback-core:其它两个模块的基础模块 logback-classic:它 ...

随机推荐

  1. hdu 1272 小希的迷宫(java实现)

    小希的迷宫 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  2. Java垃圾回收精粹 — Part1

    Java垃圾回收精粹分4个部分,本篇是第1部分.在第1部分里介绍了权衡点.对象生命周期以及全局暂停事件. 串行.并行.并发.CMS.G1.年轻代(Young Gen).新生代(New Gen).旧生代 ...

  3. 《.NET最佳实践》

    <.NET最佳实践> 基本信息 原书名:Pro .NET Best Practices 原出版社: Apress 作者: (美)Stephen Ritchie 译者: 黄灯桥 黄浩宇 李永 ...

  4. [Ubuntu]明明白白安装中文字体

    Ubuntu 6.06 dapper对中文的支持应该说是一向不错的,包括现在默认安装就包含了scim输入法.然而,一般安装的ubuntu虽然能够显示.输入中文了,但总觉 得所显示的中文像歪瓜裂枣,很是 ...

  5. Backup and restore of FAST Search for SharePoint 2010

    一个同事问我一个问题: 如果FAST Search for SharePoint 2010被full restore到了一个之前的时间点, 那么当FAST Search重新开始一个增量爬网的时候, 会 ...

  6. JSP学习笔记(三):Session和Cookie

    一.JSP Session HTTP是无状态协议,这意味着每次客户端检索网页时,都要单独打开一个服务器连接,因此服务器不会记录下先前客户端请求的任何信息.有三种方法来维持客户端与服务器的会话: 1.C ...

  7. 【Linux】Dockerfile,ubuntu默认shell不是bash?RUN source命令报错!

    Dash is not bash 在一些 docker 官方 Image 中,执行一些 .sh 文件的时候遇到了一些奇怪现象,比如: 1 2 3 # Run something like: [[ $A ...

  8. Kaggle : Display Advertising Challenge( ctr 预估 )

    原文:http://blog.csdn.net/hero_fantao/article/details/42747281 Display Advertising Challenge --------- ...

  9. ssh-keygen配置

    1) 在本地机器中的~/.ssh/目录下执行下命令, ssh-keygen -t dsa 将生成两个文件,id_dsa和id_dsa.pub. 2) 将id_dsa.pub拷贝到远程机器,并且将id_ ...

  10. .NET反编译之manager,base.AutoScaleMode修复

    使用反编译软件导出项目时,出现警告:设计器无法处理第X 行的代码:this.AutoScaleMode = AutoScaleMode.Font;方法"InitializeComponent ...