0

0

响应式编程基础:Project Reactor 简介与核心概念

舞夢輝影

舞夢輝影

发布时间:2026-01-07 14:29:50

|

397人浏览过

|

来源于php中文网

原创

project reactor 是基于 reactive streams 的java响应式框架,核心为mono(0/1元素)和flux(0-n元素),支持背压、惰性操作符链、线程调度(如boundedelastic/parallel)。

响应式编程基础:project reactor 简介与核心概念 - php中文网

Project Reactor 是 Java 生态中主流的响应式编程框架,基于 Reactive Streams 规范实现,专为构建高吞吐、低延迟、非阻塞的异步应用而设计。它不是对传统编程的替代,而是针对 I/O 密集型、事件驱动或流式数据处理场景的有力补充。

Reactor 的核心类型:Mono 与 Flux

Reactor 提供两个核心发布者(Publisher)类型,对应不同数据流形态:

  • Mono:表示最多发射 0 或 1 个元素的异步序列,适合封装单结果操作(如 findById、save 返回单对象、HTTP GET 单资源);
  • Flux:表示 0 到 N 个元素的异步序列,支持无限流(需配合背压控制),适用于集合处理、事件流、WebSocket 消息等场景。

二者都实现了 Publisher 接口,可被订阅,也提供丰富的操作符(operator)进行链式转换、组合与错误处理。

响应式流的关键机制:背压(Backpressure)

背压是 Reactive Streams 的核心约定,用于协调生产者与消费者之间的数据速率。当下游处理能力不足时,上游可暂缓发送或降级策略,避免内存溢出。

HeroPack
HeroPack

以电子游戏为灵感,用AI制作游戏化身。

下载
  • Flux 支持多种背压策略,如 onBackpressureBuffer()onBackpressureDrop()limitRate(n)
  • Mono 天然不涉及背压(最多一个元素),但其组合到 Flux 流中时会遵循整体流的背压规则;
  • 实际使用中,WebFlux 默认通过 Netty 或 Undertow 的非阻塞通道自动传播背压,开发者通常只需在数据源(如数据库驱动、消息队列客户端)启用响应式支持即可生效。

操作符链与惰性执行(Lazy Evaluation)

Reactor 的操作符(如 mapfilterflatMapretry)不会立即触发执行,而是在调用 subscribe() 或终端操作(如 block()toFuture())时才真正组装并启动数据流。

  • 这意味着声明式链是轻量的,便于复用和测试;
  • 避免在链中做副作用操作(如打印日志、修改外部状态),除非使用 doOnNextdoOnError 等“钩子”操作符;
  • 调试时可用 log() 插入链中,输出生命周期事件(onSubscribe、onNext、onComplete 等)。

线程调度与 Schedulers

Reactor 不绑定特定线程模型,但提供 Schedulers 工具类统一管理执行上下文:

  • Schedulers.boundedElastic():适用于阻塞 I/O(如 JDBC、文件读写),带线程池与队列保护;
  • Schedulers.parallel():适用于 CPU 密集型任务,固定大小线程池(通常为 CPU 核心数);
  • Schedulers.immediate():同步执行,常用于测试;
  • 使用 publishOn() 切换下游操作符执行的线程;subscribeOn() 指定整个流的起始执行上下文(仅首次生效)。

注意:WebFlux 应用中,Web 层默认运行在事件循环线程(如 Netty EventLoop),应避免在其中执行阻塞操作,必要时显式切换到 boundedElastic

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1707

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

529

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2327

2025.12.29

java接口相关教程
java接口相关教程

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

42

2026.01.19

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

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

723

2023.08.10

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

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

77

2025.09.05

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

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

38

2025.11.16

golang map原理
golang map原理

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

67

2025.11.17

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

6

2026.02.28

热门下载

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

精品课程

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

共58课时 | 5.6万人学习

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

共12课时 | 1万人学习

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

共12课时 | 1.1万人学习

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

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