0

0

Reactor 中模拟非阻塞延迟的正确实践

花韻仙語

花韻仙語

发布时间:2026-01-29 22:53:01

|

808人浏览过

|

来源于php中文网

原创

Reactor 中模拟非阻塞延迟的正确实践

在 spring reactor 中,需避免 `thread.sleep()` 等阻塞调用;应使用 `mono.delay()`、`flux.delayelements()` 等响应式原语,在不占用线程、不触发线程切换(或可控切换)的前提下,真实模拟耗时但非阻塞的操作。

响应式编程中,“模拟长时间运行操作”常被误解为“让当前线程休眠”。但 Thread.sleep() 是典型的阻塞式 I/O 风格操作——它会挂起当前线程,导致资源浪费、吞吐下降,并被 BlockHound 明确标记为非法。真正的非阻塞延迟,本质是:将任务调度到未来某个时间点执行,期间线程立即释放,用于处理其他信号

✅ 正确方式:用 Mono.delay() 构建非阻塞耗时逻辑

Mono.delay(Duration) 返回一个在指定延迟后发出 0L 的 Mono,它底层基于 ScheduledExecutorService(默认使用 Schedulers.parallel()),不阻塞任何线程,仅注册一个定时任务。你可以将其作为“时间占位符”,再通过 map 或 flatMap 衔接实际业务逻辑:

public Mono simulateLengthyProcessingOperation(Integer input) {
    return Mono.delay(Duration.ofSeconds(4)) // 非阻塞等待 4 秒(调度+唤醒)
               .map(unused -> String.format(
                   "[%d] on thread [%s] at time [%s]",
                   input, Thread.currentThread().getName(), new Date()
               ));
}
⚠️ 注意:Mono.delay() 默认在 Schedulers.parallel() 上执行,因此后续 map 中的代码也运行在该线程池中——这正是响应式“线程解耦”的体现,而非“同一线程上忙等”。

? 整合进数据流:使用 concatMap 保持顺序 + 非阻塞延迟

回到原始测试用例,若需对每个整数 1..5000 执行带延迟的处理(且要求顺序输出、不并发),应避免 map(它是同步、无调度能力的),改用 concatMap:

@Test
public void simulateLengthyProcessingOperationReactor() {
    Flux.range(1, 5000)
        .concatMap(this::simulateLengthyProcessingOperation) // 逐个订阅,顺序执行
        .subscribe(
            System.out::println,
            Throwable::printStackTrace,
            () -> System.out.println("✅ All done!")
        );
}

concatMap 保证前一个 Mono 完成后才订阅下一个,天然串行化,同时全程无阻塞、无线程抢占——完美契合“模拟长耗时但非阻塞”的需求。

Manus
Manus

全球首款通用型AI Agent,可以将你的想法转化为行动。

下载

❌ 常见误区澄清

  • Flux.delayElements() 是对元素发射节奏做延迟(如每秒发一个),不适用于“每个元素内部执行耗时逻辑”;
  • Thread.sleep() 在任何 map/filter 中都是反模式,BlockHound 会抛出 BlockingOperationException;
  • Mono.fromCallable(() -> { Thread.sleep(...); return ...; }) 仍是阻塞的——它只是把阻塞操作包装进 Mono,并未消除阻塞本质。

✅ 进阶建议:显式控制调度器(可选)

如需指定延迟执行的线程池(例如避免干扰 parallel() 默认调度器),可显式传入 Scheduler:

Mono.delay(Duration.ofSeconds(4), Schedulers.boundedElastic())
    .map(...);

boundedElastic() 更适合模拟 I/O 延迟(如数据库响应),而 parallel() 更适合 CPU 密集型延时调度。

总结

非阻塞延迟 ≠ 让线程睡觉,而是 委托给事件循环/调度器在未来唤醒任务。Reactors 提供的 Mono.delay() 和 Flux.delayElements() 正是为此设计。在模拟耗时业务逻辑时,始终优先选择 Mono.delay().flatMap(...) 或 concatMap 组合,既满足 BlockHound 合规性,又保持高吞吐与低资源开销。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

115

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

32

2026.01.26

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

503

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

87

2025.12.01

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

61

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.27

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号