当前位置:首页 > 技术分析 > 正文内容

你真的了解@Async吗?_async啥意思

ruisui884个月前 (02-14)技术分析17

使用场景:

开发中会碰到一些耗时较长或者不需要立即得到执行结果的逻辑,比如消息推送、商品同步等都可以使用异步方法,这时我们可以用到@Async。但是直接使用 @Async 会有风险,当我们没有指定线程池时,他会默认使用其Spring自带的 SimpleAsyncTaskExecutor 线程池,会不断的创建线程,当并发大的时候会严重影响性能。所以可以将异步指定线程池使用

简介:

@Async是Spring的注解,可以加在类或方法上。通俗的来讲,如果加上了这个注解,那么该类或者该方法在使用时将会进行异步处理,也就是创建一个线程来实现这个类或者方法,实现多线程。

线程池的执行顺序:

??两种使用方式:

第一种:

使用的是Spring默认的线程池SimpleAsyncTaskExecutor

接入步骤:

1.需要在@SpringBootApplication启动类或者@configure注解类上 添加注解@EnableAsync启动多线程注解。

2.在需要异步执行的方法上添加@Async注解。

默认的线程池配置:

如果需要修改默认的配置可以在yaml或者properties中添加,修改默认配置:

??执行后会打印出你的执行线程名称:

??第二种:(推荐使用)

自定义线程池,执行异步。

自定义线程池有如下模式,我们只介绍最后一种:

?重新实现接口AsyncConfigurer;

?继承AsyncConfigurerSupport;

?配置由自定义的TaskExecutor替代内置的任务执行器。

??然后添加注解到对应的方法上并指定线程池:asyncExecutor

??指定线程池的名称为自定义的线程池名称。

查看日志:

?注意事项:

查到了@Async失效的几个原因:

* 1.注解@Async的方法不是public方法;

* 2.注解@Async的返回值只能为void或Future;

* 3.注解@Async方法使用static修饰也会失效;

* 4.启动类没加@EnableAsync注解;

* 5.调用方和@Async不能在一个类中;

* 6.在Async方法上标注@Transactional是没用的,但在Async方法调用的方法上标注@Transcational是有效的;

作者:京东零售 郭春元

来源:京东云开发者社区 转载请注明来源

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/1940.html

标签: aysnc
分享给朋友:

“你真的了解@Async吗?_async啥意思” 的相关文章

Gitlab概览

Gitlab是开源的基于Git的仓库管理系统,也可以管理软件开发的整个生命周期,是项目管理和代码托管平台,支撑着整个DevOps的生命周期。Gitlab很容易选为GitHub,作为公司私有库管理的工具。我们可以用Gitlab Workflow来协同整个团队的软件开发管理过程。软件开发阶段Gitlab...

Gitlab之间进行同步备份

目前,我们公司有两个研发团队,分别在北京和武汉,考虑到访问速度的问题,原有武汉的研发环境在近端部署。也就是北京和武汉分别有两套独立的研发管理环境,虽然这解决了近端访问速度的问题,但是管理上较为分散,比如研发环境备份和恢复就是最重要的问题之一。最近,处于对安全性和合规性的考虑,希望将北京和武汉的源代码...

我的VIM配置

写一篇关于VIM配置的文章,记录下自己的VIM配置,力求简洁实用。VIM的配置保存在文件~/.vimrc中(Windows下是C:\Users\yourname \_vimrc)。VIM除了自身可配置项外,还可插件扩展。VIM的插件一般用vundle或vim-plug来管理,但我力求简单,不打算装太...

Python中的11 种数组算法

1. 创建数组 创建数组意味着留出一个连续的内存块来存储相同类型的元素。在大多数语言中,您可以在创建数组时指定数组的大小。假设您正在书架上整理一组书籍,并且您需要为正好 10 本书预留空间。功能架上的每个空间都对应于数组中的一个索引。# Example in Python arr = [1, 2,...

12种JavaScript中最常用的数组操作整理汇总

数组是最常见的数据结构之一,我们需要绝对自信地使用它。在这里,我将列出 JavaScript 中最重要的几个数组常用操作片段,包括数组长度、替换元素、去重以及许多其他内容。1、数组长度大多数人都知道可以像这样得到数组的长度:const arr = [1, 2, 3]; console.log(a...

Vue真是太好了 壹万多字的Vue知识点 超详细!

1??、Vue和其他两大框架的区别Angular 学习成本太高React 代码可读性差Vue 学习成本较低 很容易上手VUE官方: https://cn.vuejs.org/v2/guide/comparison.html?2??、Vue是什么Vue是一套用于构建用户界面的渐进式框架 "前端...