SpringBoot2.3中@Async实现异步
启动加上@EnableAsync ,需要执行异步方法上加入@Async。
在方法上加上@Async之后 底层使用多线程技术。
不使用异步
先关代码:
package com.yiyang.myfirstspringdemo.controller;
import com.yiyang.myfirstspringdemo.service.HelloService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
@RestController
@Slf4j
public class HelloController {
@Resource
private HelloService helloService;
@GetMapping("/helloAsync")
public String helloAsync() {
log.info("1");
helloService.addHello();
log.info("4");
return "hello world ==== async";
}
}
package com.yiyang.myfirstspringdemo.service;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
/**
* @Author 刘翊扬
* @Date 2020/10/3 3:14 下午
* @Version 1.0
*/
@Service
@Slf4j
public class HelloService {
public void addHello() {
log.info("2");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
log.info("3");
}
}
不使用异步处理。
正常输出的顺序:1 2 3 4
2020-10-03 15:49:41,174 INFO HelloController:24 - 1
2020-10-03 15:49:41,175 INFO HelloService:22 - 2
2020-10-03 15:49:43,182 INFO HelloService:29 - 3
2020-10-03 15:49:43,182 INFO HelloController:26 - 4
2020-10-03 15:49:43,185 INFO LogAspect:51 - RESPONSE : hello world ==== async
使用异步
在addHello()方法上面加上@Async
同时,启动类上开启异步调用
package com.yiyang.myfirstspringdemo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.EnableAsync;
@SpringBootApplication(scanBasePackages = {"com.yiyang.myfirstspringdemo"})
//@SpringBootApplication
@EnableAsync // 开启异步调用
public class MyFirstSpringDemoApplication {
public static void main(String[] args) {
SpringApplication.run(MyFirstSpringDemoApplication.class, args);
}
}
再次访问,结果是:1 4 2 3
2020-10-03 15:52:52,660 INFO HelloController:24 - 1
2020-10-03 15:52:52,666 INFO HelloController:26 - 4
2020-10-03 15:52:52,675 INFO HelloService:23 - 2
2020-10-03 15:52:52,675 INFO LogAspect:51 - RESPONSE : hello world ==== async
2020-10-03 15:52:54,681 INFO HelloService:30 - 3
注意:在同一个类中,一个方法调用另外一个有注解(比如@Async,@Transational)的方法,注解会失效
例如:
改造HelloService
package com.yiyang.myfirstspringdemo.service;
import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
/**
* @Author 刘翊扬
* @Date 2020/10/3 3:14 下午
* @Version 1.0
*/
@Service
@Slf4j
public class HelloService {
public void addHello() {
log.info("2");
sendMessage();
log.info("3");
}
@Async
public void sendMessage() {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
log.info("发送消息!!!!!");
}
}
访问结果是:1 2 3 4
2020-10-03 15:55:51,449 INFO HelloController:24 - 1
2020-10-03 15:55:51,585 INFO HelloService:17 - 2
2020-10-03 15:55:53,595 INFO HelloService:29 - 发送消息!!!!!
2020-10-03 15:55:53,596 INFO HelloService:19 - 3
2020-10-03 15:55:53,598 INFO HelloController:26 - 4
2020-10-03 15:55:53,599 INFO LogAspect:51 - RESPONSE : hello world ==== async
解决办法。。。。。。
讲sendMessage()方法放到别的类里面。
新建SendMessageService类
package com.yiyang.myfirstspringdemo.service;
import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
/**
* @Author 刘翊扬
* @Date 2020/10/3 3:37 下午
* @Version 1.0
*/
@Service
@Slf4j
public class SendMessageService {
@Async
public void sendMessage() {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
log.info("发送消息!!!!!");
log.info("5");
}
}
修改HelloService的内容
package com.yiyang.myfirstspringdemo.service;
import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
/**
* @Author 刘翊扬
* @Date 2020/10/3 3:14 下午
* @Version 1.0
*/
@Service
@Slf4j
public class HelloService {
@Resource
private SendMessageService sendMessage;
public void addHello() {
log.info("2");
sendMessage.sendMessage();
log.info("3");
}
}
访问结果是:1 2 3 4 5
2020-10-03 16:00:30,870 INFO HelloController:24 - 1
2020-10-03 16:00:30,871 INFO HelloService:22 - 2
2020-10-03 16:00:30,875 INFO HelloService:24 - 3
2020-10-03 16:00:30,891 INFO HelloController:26 - 4
2020-10-03 16:00:30,901 INFO LogAspect:51 - RESPONSE : hello world ==== async
2020-10-03 16:00:32,889 INFO SendMessageService:23 - 发送消息!!!!!
2020-10-03 16:00:32,890 INFO SendMessageService:24 - 5
那么为什么,在同一类中一个方法调用另外一个有注解(比如@Async,@Transational)的方法,注解会失效呢????
看这个博客:https://blog.csdn.net/clementad/article/details/47339519
SpringBoot2.3中@Async实现异步的更多相关文章
- ASP.NET sync over async(异步中同步,什么鬼?)
async/await 是我们在 ASP.NET 应用程序中,写异步代码最常用的两个关键字,使用它俩,我们不需要考虑太多背后的东西,比如异步的原理等等,如果你的 ASP.NET 应用程序是异步到底的, ...
- Spring中@Async注解实现“方法”的异步调用
原文:http://www.cnblogs.com/zhengbin/p/6104502.html 简单介绍: Spring为任务调度与异步方法执行提供了注解支持.通过在方法上设置@Async注解,可 ...
- HTML5中script的async属性异步加载JS
HTML5中script的async属性异步加载JS HTML4.01为script标签定义了5个属性: charset 可选.指定src引入代码的字符集,大多数浏览器忽略该值.defer 可 ...
- spring boot中使用@Async实现异步调用任务
本篇文章主要介绍了spring boot中使用@Async实现异步调用任务,小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看看吧 什么是“异步调用”? “异步调用”对应的是“同步 ...
- 【转】C# Async/Await 异步编程中的最佳做法
Async/Await 异步编程中的最佳做法 Stephen Cleary 近日来,涌现了许多关于 Microsoft .NET Framework 4.5 中新增了对 async 和 await 支 ...
- 如何在项目中使用Spring异步调用注解@Async
本文主要介绍如何使用Spring框架提供的异步调用注解@Async,异步线程池配置.异常捕获处理. 开启@Async注解支持 使用@Async注解的之前,必须在项目中启动时调用@EnableAsync ...
- .NET Web应用中为什么要使用async/await异步编程
前言 什么是async/await? await和async是.NET Framework4.5框架.C#5.0语法里面出现的技术,目的是用于简化异步编程模型. async和await的关系? asy ...
- C#中 Thread,Task,Async/Await 异步编程
什么是异步 同步和异步主要用于修饰方法.当一个方法被调用时,调用者需要等待该方法执行完毕并返回才能继续执行,我们称这个方法是同步方法:当一个方法被调用时立即返回,并获取一个线程执行该方法内部的业务,调 ...
- C++11中async中future用法(一)
async意味着异步执行代码,看如下示例: #include <future> #include <thread> #include <chrono> #inclu ...
随机推荐
- 2020.08.23 瞎扯周记之论短暂假期(QAQ)内要不要睡午觉
蒟蒻的假期都是很短暂的嘛 作为一只合格的蒟蒻 假期自然是很短暂的QAQ 只有短短的26h93360s(手动微笑) 总体来讲 假期只有两件事要干: 1.满足人体自身需求 2.满足作业需求 2.5.摸鱼 ...
- composer版本号前面`^`和`~`的区别
~1.2.3表示: 1.2.3 <= 版本号 < 1.3.0 ^1.2.3表示: 1.2.3 <= 版本号 < 2.0.0 ~1.2 表示: 1.2.0 <= 版本号 & ...
- 从后端到前端之Vue(六)表单组件
表单组件 做项目的时候会遇到一个比较头疼的问题,一个大表单里面有好多控件,一个一个做设置太麻烦,更头疼的是,需求还总在变化,一会多选.一会单选.一会下拉的,变来变去的烦死宝宝了. 那么怎么解决这个问题 ...
- HTTP协议中的提交方式和解释POST、GET、HEAD、PUT等
最基本的方法有4种,分别是GET,POST,PUT,DELETE HTTP中的GET,POST,PUT,DELETE就对应着对这个资源的查,改,增,删4个操作 GET一般用于获取/查询资源信息,而PO ...
- HTTPS建立过程
由于HTTPS建立过程经常忘记,固记录 HTTPS建立流程 客户端发起SSL连接 服务端发送证书(证书中包含了服务端公钥) 客户端根据已有证书判断是否是可信任的(客户端决定是否继续) 服务端要求客户端 ...
- Java面试题(1):详解int与Integer
Java面试题(1):详解int与Integer int与Integer的区别 int是Java的基本数据类型之一,Integer是int的包装类 int直接再内存中储存值,Integer进行new操 ...
- Java 得到指定时间加半个小时之后得时间
Calendar c = Calendar.getInstance(); c.setTime(cur); //设置时间 c.add(Calendar.MINUTE, 1); //日期分钟加1,Cale ...
- window下dos命令
引用 Windows下DOS命令 显示当前目录所有文件 dir 创建文件夹 md test 创建文件 cd>a.txt 删除文件 del a.txt 删除文件夹 rd test 在某磁盘打开不同 ...
- TP6.0 一对一模型关联 belongsTo 相对关联(反向关联)
1. 创建数据表 一对一反向关联使用率很高 附表关联主表称为反向关联,又称为相对关联(tp官方手册这样叫) -- 分类表 CREATE TABLE `category` ( `id` int(10) ...
- Linux:基础命令三
一.软链接 相当于windows中的快捷方式,为了方便用户在使用时更快找到 ln -s /application/appche2.2.0/ /application/appche 注意: ...