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

21.《SpringBoot 异步编程@Async与CompletableFuture》

SpringBoot 异步编程

文章导读

本文系统讲解 Spring Boot 异步编程的核心技术与实践方案,涵盖从基础使用到高级优化的全链路知识。通过深入剖析 @Async 注解原理、线程池配置策略、异步异常处理机制等关键技术点,结合典型业务场景的代码示例,帮助开发者掌握构建高性能异步系统的核心方法。文章最后提供线程池监控与优化的实战建议。


一、入门篇:基础异步处理

1.1 启用异步支持

在 Spring Boot 主类或配置类添加注解:

@SpringBootApplication
@EnableAsync  // 开启异步处理支持
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}

1.2 基础异步方法

@Service
public class OrderService {@Async  // 标记为异步方法public void processOrderAsync(Order order) {// 模拟耗时操作log.info("开始处理订单:{}", order.getId());sleep(Duration.ofSeconds(3));log.info("订单处理完成:{}", order.getId());}
}

代码说明

  • 方法返回类型必须为 voidFuture 类型
  • 调用方与被调用方必须在不同类中(AOP 代理限制)
  • 默认使用 SimpleAsyncTaskExecutor(非池化)

二、进阶篇:线程池与高级控制

2.1 线程池配置

# application.yml
spring:task:execution:pool:core-size: 5max-size: 20queue-capacity: 100keep-alive: 60sthread-name-prefix: async-exec-

2.2 自定义线程池

@Configuration
public class AsyncConfig {@Bean("customExecutor")public Executor customTaskExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();executor.setCorePoolSize(10);executor.setMaxPoolSize(50);executor.setQueueCapacity(200);executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());executor.setThreadNamePrefix("custom-async-");executor.initialize();return executor;}
}

2.3 带返回值的异步

@Async("customExecutor")
public CompletableFuture<Report> generateReportAsync() {return CompletableFuture.supplyAsync(() -> {// 复杂报表生成逻辑return reportService.generateComplexReport();});
}

2.4 异常处理机制

public class CustomAsyncExceptionHandler implements AsyncUncaughtExceptionHandler {@Overridepublic void handleUncaughtException(Throwable ex, Method method, Object... params) {log.error("异步方法执行异常: {} - {}", method.getName(), ex.getMessage());// 发送报警或进行补偿操作alertService.sendAsyncErrorAlert(method, ex);}
}

三、精通篇:生产级最佳实践

3.1 异步链路追踪

@Async
public CompletableFuture<Void> asyncOperation() {MDC.put("traceId", TracingContext.getCurrentTraceId());try {// 业务逻辑} finally {MDC.clear();}
}

3.2 异步限流控制

@Bean
public Executor rateLimitedExecutor() {Semaphore semaphore = new Semaphore(50);  // 并发许可数return new DelegatedExecutor(Executors.newFixedThreadPool(20), runnable -> {semaphore.acquire();try {runnable.run();} finally {semaphore.release();}});
}

3.3 监控指标体系

@Bean
public ExecutorServiceMonitor executorMonitor(ThreadPoolTaskExecutor executor) {return new ExecutorServiceMonitor(executor.getThreadPoolExecutor(), "order_async_pool");
}

监控关键指标

  • 活跃线程数
  • 队列积压量
  • 拒绝任务数
  • 任务完成平均耗时

四、架构级应用

4.1 异步事件驱动

@EventListener
@Async
public void handleOrderEvent(OrderCreatedEvent event) {// 异步处理领域事件inventoryService.reduceStock(event.getOrder());paymentService.processPayment(event.getOrder());
}

4.2 分布式异步协调

@Async
public CompletableFuture<Boolean> distributedTask() {return CompletableFuture.supplyAsync(() -> {String taskId = distributedService.createTask();while(true) {TaskStatus status = distributedService.getStatus(taskId);if(status.isCompleted()) {return true;}sleep(Duration.ofSeconds(1));}});
}

性能优化建议

  1. 队列容量策略:根据业务特点选择合适队列类型

    • CPU密集型:使用有界队列防止内存溢出
    • IO密集型:使用无界队列提高吞吐量
  2. 拒绝策略选择

    • CallerRunsPolicy:保证任务不丢失
    • DiscardOldestPolicy:适合实时性要求低的场景
  3. 线程池预热

@PostConstruct
public void preheatThreadPool() {IntStream.range(0, corePoolSize).forEach(i -> executor.execute(() -> {}));
}

结语

Spring 异步编程能显著提升系统吞吐量,但需注意:

  1. 避免过度异步化导致线程资源耗尽
  2. 事务边界需要特殊处理(@Transactional 与 @Async 的协作)
  3. 异步任务应做好幂等性设计

通过合理配置线程池参数、完善的监控体系以及正确的架构设计,开发者可以构建出高可靠、高性能的异步处理系统。希望本文能帮助读者全面掌握 Spring 异步编程的精髓。

相关文章:

21.《SpringBoot 异步编程@Async与CompletableFuture》

SpringBoot 异步编程 文章导读 本文系统讲解 Spring Boot 异步编程的核心技术与实践方案&#xff0c;涵盖从基础使用到高级优化的全链路知识。通过深入剖析 Async 注解原理、线程池配置策略、异步异常处理机制等关键技术点&#xff0c;结合典型业务场景的代码示例&#xff0c…...

激光雷达YDLIDAR X2 SDK安装

激光雷达YDLIDAR X2 SDK安装 陈拓 2024/12/15-2024/12/19 1. 简介 YDLIDAR X2官方网址https://ydlidar.cn/index.html‌YDLIDAR X2 YDLIDAR X2是一款高性能的激光雷达传感器&#xff0c;具有以下主要特点和规格参数‌&#xff1a; ‌测距频率‌&#xff1a;3000Hz ‌扫描频…...

大模型在肝硬化风险预测及临床决策中的应用研究

目录 一、引言 1.1 研究背景与意义 1.2 研究目的与创新点 1.3 研究方法与数据来源 二、肝硬化及大模型相关理论基础 2.1 肝硬化概述 2.2 大模型技术原理 2.3 大模型在医疗领域的应用现状 三、大模型预测肝硬化术前风险 3.1 术前风险因素分析 3.2 大模型预测术前风险…...

计算机毕业设计SpringBoot+Vue.js母婴商城(源码+LW文档+PPT+讲解+开题报告)

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…...

Java多线程三:补充知识

精心整理了最新的面试资料&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 Lambda表达式 简介&#xff1a; 希腊字母表中排序第十一位的字母&#xff0c;英语名称为Lambda避免匿名内部类定义过多其实质属于函数式编程的概念 为什么要使用lam…...

计算机网络————(一)HTTP讲解

基础内容分类 从TCP/IP协议栈为依托&#xff0c;由上至下、从应用层到基础设施介绍协议。 1.应用层&#xff1a; HTTP/1.1 Websocket HTTP/2.0 2.应用层的安全基础设施 LTS/SSL 3.传输层 TCP 4.网络层及数据链路层 IP层和以太网 HTTP协议 网络页面形成基本 流程&#xff1a…...

stream流常用方法

1.reduce 在Java中&#xff0c;可以使用Stream API的reduce方法来计算一个整数列表的乘积。reduce方法是一种累积操作&#xff0c;它可以将流中的元素组合起来&#xff0c;返回单个结果。对于计算乘积&#xff0c;你需要提供一个初始值&#xff08;通常是1&#xff0c;因为乘法…...

最新扣子(Coze)案例教程:全自动DeepSeek 写影评+批量生成 + 发布飞书,提效10 倍!手把手教学,完全免费教程

&#x1f468;‍&#x1f4bb;群里有同学是做影视赛道的博主&#xff0c;听说最近DeepSeek这么火&#xff0c;咨询能不能用DeepSeek写影评&#xff0c;并整理电影数据资料&#xff0c;自动发布到飞书文档&#xff0c;把每天的工作做成一个自动化的流程。 那今天斜杠君就为大家…...

数据结构:动态数组vector

vector 是 C 标准库的动态数组。 在C语言中一般初学者会使用malloc&#xff0c;int[n]等方式来创建静态数组&#xff0c;但是这种方式繁琐且容易出错。我们做算法题一般使用动态数组vector&#xff0c; 并且在刷题网站的题目给的输入一般也是vector类型。 示例&#xff1a;vect…...

【HeadFirst系列之HeadFirst设计模式】第9天之模板方法模式:从咖啡和茶到Spring框架,掌握设计模式的精髓

模板方法模式&#xff1a;从咖啡和茶到Spring框架&#xff0c;掌握设计模式的精髓 《Head First 设计模式》是一本经典的设计模式入门书籍&#xff0c;它以轻松幽默的方式讲解了设计模式的核心思想。其中&#xff0c;模板方法模式是一个非常简单但非常实用的设计模式&#xff…...

力扣hot100——排序链表(常见方法,归并排序)

解题思路&#xff1a; 分解&#xff08;Divide&#xff09;&#xff1a;将待排序的列表递归地分成两半&#xff0c;直到每个子列表只包含一个元素&#xff08;此时每个子列表都是有序的&#xff09;。解决&#xff08;Conquer&#xff09;&#xff1a;递归地对每个子列表进行排…...

使用 DeepSeek 和 ECharts 实现大屏数据可视化

引言 在当今数据驱动的时代,数据可视化成为了分析和展示数据的重要手段。大屏数据可视化不仅能够直观地展示数据,还能帮助决策者快速理解复杂信息。本文将介绍如何结合 DeepSeek(一个强大的数据处理与分析工具)和 ECharts(一个流行的数据可视化库)来实现大屏数据可视化。…...

基于springboot+vue的新生报到管理系统

一、系统架构 前端&#xff1a;vue | element-ui | echarts 后端&#xff1a;springboot | mybatis-plus | jwt 环境&#xff1a;jdk1.8 | mysql | maven 二、代码及数据 三、功能介绍 01. 登录 02. 首页 03. 管理员-系统管理-用户管理 04. 管理员-系统…...

【面试系列】Java开发--AI常见面试题

文章目录 1、实际工作或学习中用过哪些Ai工具1.1、AI编程1.2、AI对话聊天1.3、AI图像工具1.4、AI办公工具 2、谈谈你知道的AI领域的一些常见词汇及其含义的理解&#xff1f; 例如AIGC、LLM、DeepLearning分别是什么意思&#xff1f;2.1、AIGC&#xff08;Artificial Intelligen…...

Maven 基础环境搭建与配置(二)

四、本地仓库配置&#xff0c;存储依赖 在 Maven 的世界里&#xff0c;本地仓库就像是一个 “私人储物间”&#xff0c;专门用来存放项目所需的各种依赖构件&#xff0c;如 JAR 包、WAR 包等。当我们构建项目时&#xff0c;Maven 会首先在本地仓库中查找所需的依赖&#xff0c…...

了解ffmpeg,安装并配置环境变量

一、了解FFmpeg FFmpeg 是一个功能强大的开源多媒体框架&#xff0c;能够处理音视频的录制、转换和流媒体传输。它由 Fabrice Bellard 发起&#xff0c;采用 LGPL/GPL 许可证&#xff0c;广泛应用于各种平台&#xff0c;包括 Linux、Windows 和 macOS 什么是FFmpeg&#xff1…...

Deepseek reasoning-content 透出调研

Deepseek reasoning-content 透出调研 部署方式&#xff1a;Docker Ollama Deepseek-R1:8b 参考&#xff1a; https://help.apiyi.com/deepseek-reasoning-content-guide.htmlhttps://yuluo-yx.github.io/blog/%E4%BD%BF%E7%94%A8-Ollama-%E9%83%A8%E7%BD%B2-DeepSeek-%E5…...

Codes 开源免费研发项目管理平台 2025年第一个大版本3.0.0 版本发布及创新的轻IPD实现

Codes 简介 Codes 是国内首款重新定义 SaaS 模式的开源项目管理平台&#xff0c;支持云端认证、本地部署、全部功能开放&#xff0c;并且对 30 人以下团队免费。它通过创新的方式简化研发协同工作&#xff0c;使敏捷开发更易于实施。并提供低成本的敏捷开发解决方案&#xff0…...

Leetcode K个一组翻转链表

双指针法&#xff0c;java solution class Solution {public ListNode reverseKGroup(ListNode head, int k) {if(head null || head.next null) return head;//设置pre和index节点ListNode pre head, index head.next;int m 0;while(m < k && index ! null) …...

电脑开机一段时间就断网,只有重启才能恢复网络(就算插网线都不行),本篇文章直接解决,不要再看别人的垃圾方法啦

下面的是我解决问题的心路历程&#xff0c;不想看的可以直接跳到解决方法上面&#xff01; 内心思路&#xff1a; w11电脑更新过系统后&#xff0c;我的电脑是常年不关机的&#xff0c;但是一天突然断网&#xff0c;试了很多方法都连不上&#xff0c;重启电脑就会好&#xff0…...

CANopen设备现场配置避坑指南:LSS协议详解与节点ID/波特率设置全流程

CANopen设备现场配置避坑指南&#xff1a;LSS协议详解与节点ID/波特率设置全流程 当你面对一批出厂节点ID相同或未知的CANopen从站设备时&#xff0c;如何高效、安全地完成节点ID和网络波特率的配置&#xff1f;这可能是每个现场工程师都曾头疼的问题。本文将深入解析LSS&#…...

AD7606多路采集时序翻车实录:从‘8+3路异常’到‘下降沿触发’的保姆级避坑指南

AD7606多路采集时序翻车实录&#xff1a;从‘83路异常’到‘下降沿触发’的保姆级避坑指南 当你在深夜的实验室里盯着示波器上那些跳动的波形&#xff0c;突然发现采集到的数据出现莫名其妙的错乱——前8路信号正常&#xff0c;后3路却像被施了魔法一样完全不对。这种场景对于使…...

终极实战指南:用Python高效实现手机号与QQ号关联查询

终极实战指南&#xff1a;用Python高效实现手机号与QQ号关联查询 【免费下载链接】phone2qq 项目地址: https://gitcode.com/gh_mirrors/ph/phone2qq phone2qq是一个基于Python的轻量级工具&#xff0c;专门用于通过手机号查询关联的QQ号码&#xff0c;适用于技术开发、…...

如何快速配置个性化游戏世界:ReTerraForged地形引擎终极指南

如何快速配置个性化游戏世界&#xff1a;ReTerraForged地形引擎终极指南 【免费下载链接】ReTerraForged TerraForged for modern MC versions 项目地址: https://gitcode.com/gh_mirrors/re/ReTerraForged 想要在Minecraft中打造独一无二的游戏世界吗&#xff1f;厌倦了…...

Degrees of Lewdity 中文本地化版:从新手到专家的完整体验指南

Degrees of Lewdity 中文本地化版&#xff1a;从新手到专家的完整体验指南 【免费下载链接】Degrees-of-Lewdity-Chinese-Localization Degrees of Lewdity 游戏的授权中文社区本地化版本 项目地址: https://gitcode.com/gh_mirrors/de/Degrees-of-Lewdity-Chinese-Localizat…...

ZYNQ 7045/690T项目实战:用Vitis/SDK给GD SPI Flash固化镜像的完整流程(含uboot文件替换指南)

ZYNQ 7045/690T项目实战&#xff1a;GD SPI Flash镜像固化全流程解析 在嵌入式系统开发中&#xff0c;ZYNQ SoC平台的启动配置一直是项目落地的关键环节。对于采用国产GD SPI Flash作为存储介质的开发者而言&#xff0c;如何绕过ID核查机制完成系统固化&#xff0c;成为实际工程…...

VMware Unlocker 3.0:终极指南 - 在Windows/Linux上免费运行macOS虚拟机

VMware Unlocker 3.0&#xff1a;终极指南 - 在Windows/Linux上免费运行macOS虚拟机 【免费下载链接】unlocker VMware Workstation macOS 项目地址: https://gitcode.com/gh_mirrors/unloc/unlocker 想在普通电脑上体验macOS系统吗&#xff1f;VMware Unlocker 3.0正是…...

首篇全新情景认知视角的大模型Agent综述

大家都在谈 Agent&#xff0c;真正拉开差异的关键&#xff0c;来自我们怎样理解 Agent。 若将 Agent 理解为由规划、记忆、行动、反思组成的系统&#xff0c;读者很快会记住一串模块名&#xff0c;却较难抓住它在真实环境里怎样持续工作。中科大的这篇 Survey 试图把问题向前推…...

XUnity.AutoTranslator完整教程:轻松实现Unity游戏实时翻译

XUnity.AutoTranslator完整教程&#xff1a;轻松实现Unity游戏实时翻译 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为看不懂的外文游戏而烦恼吗&#xff1f;XUnity.AutoTranslator是一款功能强大…...

PNG图片处理踩坑记:lodepng解码RGBA时,为什么你的RAW文件总出错?(附Hex Editor排查全流程)

PNG解码陷阱&#xff1a;lodepng与二进制文件操作的深度避坑指南 第一次看到自己解码的PNG图片在ImageJ中呈现出一片混乱的色块时&#xff0c;我盯着屏幕足足愣了三分钟。作为有五年C开发经验的程序员&#xff0c;本以为调用一个轻量级的PNG解码库不过是几行代码的事&#xff0…...