当前位置: 首页 > article >正文

springboot中的异步任务

在springboot项目中可以通过@EnableAsync+@Async的方式简化异步操作,下文使用springboot:3.2.1 源码分析

若一个bean中的公共方法上标注了@Async,在系统启动时,会给这个类创建一个代理对象,并将该代理对象作为bean注册到spring容器中
当调用带有@Async注解的方法时,实际上是调用了代理对象的方法,在代理对象的方法中将真正的方法交给线程池去执行

原理分析

代理方法执行时,AsyncExecutionInterceptor#invoke调用determineAsyncExecutor()方法获取异步执行器,然后将真实方法的执行交给异步执行器
在这里插入图片描述
获取@Async指定的异步执行器,若未指定,则使用默认的异步执行器
在这里插入图片描述

获取默认的异步执行器

  • 默认的异步执行器类型是ThreadPoolTaskExecutor,由org.springframework.boot.autoconfigure.task.TaskExecutorConfigurations.TaskExecutorConfiguration向spring容器中注册
  • 且核心线程数默认是8,阻塞队列容量默认是Integer.MAX_VALUE,可见默认的设置在生产环境使用时存在资源耗尽的风险。可通过配置文件调整(配置项对应类:org.springframework.boot.autoconfigure.task.TaskExecutionProperties)

如果AsyncConfigurer提供了Executor,则使用该Executor作为默认执行器,否则通过getDefaultExecutor方法获取默认执行器
在这里插入图片描述
AsyncExecutionInterceptor#getDefaultExecutor方法中,首先从父类方法中获取执行器(从spring容器中获取org.springframework.core.task.TaskExecutor类型的bean或者name是taskExecutor的bean),若为空,则使用SimpleAsyncTaskExecutor
在这里插入图片描述
在这里插入图片描述
默认情况下,spring容器中并没有TaskExecutor类型的bean,但是在TaskExecutorConfiguration(该配置类是由TaskExecutionAutoConfiguration自动配置类使用@Import导入)配置类中,向spring容器中注册了name是taskExecutor的bean
在这里插入图片描述

自定义异步执行器

自定义默认异步执行器

以下两种方式都是在自定义默认的异步执行器,也就说@Async不指定线程池时使用的默认异步执行器

  1. 自定义配置类,并实现org.springframework.scheduling.annotation.AsyncConfigurer接口,重写getAsyncExecutor方法
  2. 向容器中注册TaskExecutor类型的bean,覆盖内置的TaskExecutor
自定义普通异步执行器
  • 自定义普通异步执行器的bean名称,不可设置为taskExecutor,且类型不可以是TaskExecutor,否则会成为默认异步执行器
  • 可创建org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor对象,并自定义其属性值,然后将该对象注册到spring容器中

异常处理

异步方法的异常捕获和处理
在这里插入图片描述
在这里插入图片描述
默认的异常处理器SimpleAsyncUncaughtExceptionHandler
在这里插入图片描述
在这里插入图片描述
示例

2024-09-20T15:59:20.776+08:00 ERROR 34764 --- [         task-1] .a.i.SimpleAsyncUncaughtExceptionHandler : Unexpected exception occurred invoking async method: public void com.example.box.dynamicproxy.TestJdkProxyServiceImpl.run()

java.lang.RuntimeException: 公司又停发工资了!!!
	at com.example.box.dynamicproxy.TestJdkProxyServiceImpl.run(TestJdkProxyServiceImpl.java:14) ~[classes/:na]
	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:na]
	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) ~[na:na]

自定义异常处理器

配置类实现AsyncConfigurer接口的getAsyncUncaughtExceptionHandler()方法,返回一个自定义的AsyncUncaughtExceptionHandler实现类的实例
在这里插入图片描述


http://www.kler.cn/a/317057.html

相关文章:

  • 【Linux】-学习笔记03
  • Fastapi使用MongoDB作为数据库
  • 读数据质量管理:数据可靠性与数据质量问题解决之道03数据目录
  • flink sql + kafka + mysql 如何构建实时数仓
  • 如何在Puppeteer中实现表单自动填写与提交:问卷调查
  • 鸿蒙进阶篇-属性动画-animateTo转场动画
  • Matplotlib-数据可视化详解
  • 瑞芯微RK3588开发板Linux系统添加自启动命令的方法,深圳触觉智能Arm嵌入式鸿蒙硬件方案商
  • git show 命令
  • Unity中Rigidbody 刚体组件和Rigidbody类是什么?
  • 【flex-shrink】计算 flex弹性盒子的子元素的宽度大小
  • 【27】C++项目练习
  • 循环中用sleep
  • linux atomic 原子变量操作
  • 【Python报错已解决】AttributeError: ‘WindowsPath‘ object has no attribute ‘rstrip‘
  • 生成式AI:ChatGPT及其在各行业的应用前景
  • git学习报告
  • 深入探索迭代器模式的原理与应用
  • 从零开始写一个建立FAT32文件系统程序
  • MFC - 复杂控件_2
  • 【安装教程】Windows环境下Apache Jena Fuseki的安装与配置
  • qt-C++笔记之作用等同的宏和关键字
  • 模拟电路工程师面试题
  • 如何解决npm下载Puppeteer卡死的问题
  • YOLOv9改进策略【注意力机制篇】| 2024 SCI TOP FCAttention 即插即用注意力模块,增强局部和全局特征信息交互
  • Java面试指南(基础篇)