您的位置:首页 > 文旅 > 旅游 > 衢州网站推广_厦门百度关键词优化_中国十大搜索引擎排名_重庆人社培训网

衢州网站推广_厦门百度关键词优化_中国十大搜索引擎排名_重庆人社培训网

2025/3/21 21:51:04 来源:https://blog.csdn.net/qq_39609993/article/details/146403966  浏览:    关键词:衢州网站推广_厦门百度关键词优化_中国十大搜索引擎排名_重庆人社培训网
衢州网站推广_厦门百度关键词优化_中国十大搜索引擎排名_重庆人社培训网

前言

在现代高并发、高响应的应用场景中,Spring Boot 的异步处理能力是提升系统吞吐量和用户体验的关键技术之一。无论是实时数据推送、大文件传输,还是复杂异步任务调度,Spring Boot 提供了多种灵活的异步处理机制以满足不同需求。本文将从实际开发角度出发,系统解析 Spring Boot 中常见的异步处理方式,包括但不限于 DeferredResult、ResponseBodyEmitter 等特殊返回对象。

一、核心对象对比

对象传输方式特性适用场景协议支持
DeferredResult单次响应线程间解耦、可跨请求处理结果长轮询、第三方回调、异步任务处理通用 HTTP
ResponseBodyEmitter分块流式传输支持多次数据发送、自动处理内容类型分块传输日志、实时进度条HTTP 1.1+
SseEmitter事件流符合 SSE 规范、自动重连、事件结构化实时股票行情、聊天消息推送、监控数据流Server-Sent Events
StreamingResponseBody一次性流式写入直接操作 OutputStream、内存占用低大文件下载、视频流传输通用 HTTP

二、详细说明与示例

1. DeferredResult(延迟结果)

特点

  • 通过其他线程设置结果值(如 MQ 消费者、定时任务)
  • 支持超时处理和回调方法(onCompletion/onTimeout)
  • 适用于需要外部事件触发的场景

代码示例

@GetMapping("/order/status")
public DeferredResult<String> checkOrderStatus() {DeferredResult<String> deferredResult = new DeferredResult<>(30000L, "Timeout!");// 模拟异步处理(如MQ监听)CompletableFuture.runAsync(() -> {try {Thread.sleep(5000);deferredResult.setResult("ORDER_COMPLETED");} catch (Exception e) {deferredResult.setErrorResult(e);}});return deferredResult;
}

2. ResponseBodyEmitter(响应体发射器)

特点

  • 支持多次 send() 方法分块发送数据
  • 自动处理 Content-Type: text/event-stream
  • 需要自行管理数据格式

代码示例

@GetMapping("/progress")
public ResponseBodyEmitter showProgress() {ResponseBodyEmitter emitter = new ResponseBodyEmitter();Executors.newSingleThreadExecutor().submit(() -> {for (int i = 0; i <= 100; i += 10) {try {emitter.send("Progress: " + i + "%\n");Thread.sleep(1000);} catch (Exception e) {emitter.completeWithError(e);break;}}emitter.complete();});return emitter;
}

3. SseEmitter(SSE 发射器)

特点

  • 符合 W3C SSE 规范(事件 ID、重试机制)
  • 浏览器自动重连(默认 3 秒)
  • 结构化事件发送(event/data/id)

代码示例

@GetMapping("/stock")
public SseEmitter streamStockPrices() {SseEmitter emitter = new SseEmitter(60000L);ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);scheduler.scheduleAtFixedRate(() -> {try {StockPrice price = stockService.getLatestPrice();emitter.send(SseEmitter.event().id(UUID.randomUUID().toString()).name("stockUpdate").data(price));} catch (IOException e) {scheduler.shutdown();}}, 0, 1, TimeUnit.SECONDS);return emitter;
}

4. StreamingResponseBody(流式响应体)

特点

  • 直接操作底层 OutputStream
  • 适合处理二进制数据流
  • 需要手动设置 Content-Type

代码示例

@GetMapping("/download")
public StreamingResponseBody downloadLargeFile() {return outputStream -> {try (InputStream in = new FileInputStream("/data/large.zip")) {byte[] buffer = new byte[4096];int bytesRead;while ((bytesRead = in.read(buffer)) != -1) {outputStream.write(buffer, 0, bytesRead);outputStream.flush();}}};
}

三、场景选择指南

需求场景推荐方案补充说明
实时聊天消息推送SseEmitter利用浏览器自动重连机制
文件下载/视频流StreamingResponseBody直接操作字节流效率更高
需要与第三方系统交互的长耗时操作DeferredResult通过 MQ 或回调通知结果
分阶段显示处理进度(如数据导入)ResponseBodyEmitter比 SSE 更灵活的自由格式输出
需要兼容低版本浏览器DeferredResult + 轮询降级为传统 AJAX 轮询方案

通过合理选择这些异步处理对象,可以显著提升 Spring Boot 应用的吞吐量和实时响应能力,建议根据具体业务场景的特点进行技术选型。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com