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

SpringBoot异步接口实现 提升吞吐量

前言
  • Servlet 3.0之前:HTTP请求由单一线程处理。
  • Servlet 3.0之后:支持异步处理,提高系统吞吐量。
SpringBoot 异步接口实现方式
  1. AsyncContext:Servlet层级,不常用。
  2. Callable:使用java.util.concurrent.Callable
  3. WebAsyncTask:Spring封装的Callable,提供回调功能。
  4. DeferredResult:延迟结果设置,适用于结果生成可能在其他线程。
Callable 实现
  • Controller返回Callable<String>
  • 处理过程
    • Spring MVC调用request.startAsync()
    • 使用AsyncTaskExecutor在单独线程处理。
    • 释放Servlet容器线程,保持response状态。
    • Callable结果产生后,请求返回Servlet容器完成处理。
WebAsyncTask 实现
  • 特点:提供超时、错误和完成回调。
  • 示例
    @GetMapping("/webAsyncTask")
    public WebAsyncTask<String> webAsyncTask() {WebAsyncTask<String> result = new WebAsyncTask<>(30003, () -> "success");result.onTimeout(() -> {log.info("timeout callback");return "timeout callback";});result.onCompletion(() -> log.info("finish callback"));return result;
    }
    
DeferredResult 实现
  • 特点:结果可能在其他线程设置。
  • 示例
    @GetMapping("/testDeferredResult")
    public DeferredResult<String> testDeferredResult(){DeferredResult<String> deferredResult = new DeferredResult<>();deferredResultMap.put("test", deferredResult);return deferredResult;
    }
    
  • 处理过程
    • 保存DeferredResult
    • Spring MVC调用request.startAsync()
    • 应用程序在其他线程设置DeferredResult值。
线程池配置
  • 自定义线程池:提供异步请求使用的线程池。
  • 配置示例
    @Bean("mvcAsyncTaskExecutor")
    public AsyncTaskExecutor asyncTaskExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();executor.setCorePoolSize(5);executor.setMaxPoolSize(10);executor.setQueueCapacity(10);executor.setThreadNamePrefix("fyk-mvcAsyncTask-Thread-");executor.setRejectedExecutionHandler(new ThreadPoolExecutor.DiscardPolicy());executor.setWaitForTasksToCompleteOnShutdown(true);executor.setAwaitTerminationSeconds(30);executor.initialize();return executor;
    }
    
异步请求配置
  • 配置类FykWebMvcConfigurer实现WebMvcConfigurer
  • 超时时间设置configurer.setDefaultTimeout(60001);
使用异步请求的场景
  • 适用场景:请求中CPU大量时间处于休息状态。
  • 不适用场景:CPU持续高负荷运算。
结论

异步请求通过释放主线程提高吞吐量,但需合理使用以避免增加耗时。了解异步接口实现有助于优化SpringBoot应用性能。

http://www.lryc.cn/news/390044.html

相关文章:

  • C语言快速学习笔记
  • 如何选择易用性高的项目管理软件?
  • vue3基于uni-app 封装小程序request请求
  • YOLO在目标检测与视频轨迹追踪中的应用
  • 版本控制系统:Git 纯应用(持续更新)
  • 从0开始搭建vue项目
  • Java框架常见面试题
  • linux c 应用编程定时器函数
  • 设备调试上位机GUI
  • 项目管理系统厂商:奥博思发布《项目管理系统助力 IPD 高效落地》演讲
  • Java项目总结1
  • Java中的类加载机制详解
  • SwiftUI 中 Grid 内多个 NavigationLink 同时发生导航之诡异问题的解决
  • 51单片机第21步_将TIM0用作两个8位定时器同时将TIM1用作波特率发生器
  • API-元素尺寸与位置
  • C语言中的基础指针操作
  • LabVIEW环境下OCR文字识别的实现策略与挑战解析
  • 中英双语介绍美国的州:堪萨斯州(Kansas)
  • 信息收集---端口服务信息收集
  • Python知识点背诵手册,超详细知识梳理
  • 【Pytorch实用教程】如何在多个GPU上使用分布式数据并行进行训练模型
  • PIL,OpenCV,Pytorch处理图像时的通道顺序(颜色,长宽深)
  • 经纬恒润亮相2024世界智能产业博览会
  • Python序列化和反序列化
  • Stream toArray 好过collect
  • qt/c++/mysql教务管理系统
  • Echarts公共方法
  • 鸿蒙学习(二)
  • 企业机构营销目前106短信群发还有用吗?此文告诉你该如何抉择!
  • DJYGUI AI低代码图形编程开发平台:开启嵌入式软件图形编程新纪元