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 ...
随机推荐
- Java学习笔记——java基础
2020.9.1 学习来自 https://www.liaoxuefeng.com/wiki/1252599548343744/1255883729079552 一.变量和数据类型 基本数据类型 基本 ...
- composer分析(二)结合PSR-4
composer分析(二)结合PSR-4 PSR-4提供了一种文件和路径映射关系,非常类似文件系统的组织结构 全限定类名 \<NamespaceName>(\<SubNamespac ...
- vue 中使用echarts
前言:在vue2.0中使用百度echarts有三种解决方案. 一.原始方法直接使用 这样每次都要获取图表dom元素 然后通过setOption渲染数据,最后在mounted中初始化.很麻烦. < ...
- Java 与 Mysql连接,并分页显示
这是我第一个上规模的Java项目,我们必须在一周内完成的作业,零基础学习Java,网上收集了很多资料,逐渐对面向对象的思想有所了解,但还是半灌水,后期打算结合项目系统地学习一遍Java.老师布置的任务 ...
- SSM框架之mybatis极速入门!
- 【好文分享】为什么强烈禁止开发人员使用isSuccess作为变量名
原文来自阿里云hollies:https://developer.aliyun.com/article/701413 简介: 在日常开发中,我们会经常要在类中定义布尔类型的变量,比如在给外部系统提 ...
- 图像通道、RGB与色彩体系
通道(Channels) 图像的通道指的是什么?是不是灰度图的通道数为1,彩色图的通道为3 ? 图像通道,在RGB色彩模式下就是指那单独的红色.绿色.蓝色部分.也就是说,一幅完整的图像,是由红色绿色蓝 ...
- springboot +jsp项目打包部署到华为云服务器
注:打包之前先保证你的项目本地运行没问题. 一.打包 打包有两种方式,打成jar包和打成war包.因为springboot有内置的服务器,所以选择打成jar包,这样云服务器就不用装tomcat了. 打 ...
- 用于测试 SqlAnalyzer1.01 的21个测试用例
感慨:当年看着 https://www.cnblogs.com/heyang78/p/11451814.html 一文望洋兴叹,如今我也自己做出来了! 21. 原文=select name, cnt ...
- MyBatis源码骨架分析
源码包分析 MyBatis 源码下载地址:https://github.com/MyBatis/MyBatis-3 MyBatis源码导入过程: 下载MyBatis的源码 检查maven的版本,必须是 ...