Spring响应式编程之Reactor背压机制

2024-06-23 22:04

本文主要是介绍Spring响应式编程之Reactor背压机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背压机制

在生产-发布模式下,由于事件处理平台大小有限制,生产者和消费者存在处理速度的差异,生产者不能持续不断的发布数据并推送,即流量控制问题。异步式编程采用背压机制来保持系统稳定。

背压机制简单理解,通过一种反馈机制来告知生产者当前消费者的处理能力,生产者动态调整数据生成的速率,确保消费者能够处理生产者产生的数据。

背压的策略包括:

缓冲(buffering):将超出消费者处理能力的数据暂存在缓冲区中,等消费者有能力处理时再发送。这会实现无限缓冲,并可能导致OutOfMemoryError,因此一般适用于消费者偶尔会被短暂压垮,但整体处理能力足够栋场景;

丢弃(dropping):丢弃超出消费者处理能力的数据,只保留最新的数据或最重要的数据。一般适用于消费者不关心部分数据的丢失;

最新(lastest):只保留最新的数据,丢弃旧的数据,确保消费者始终处理最新的数据。一般适用于实时的场景;

错误(error):当消费者无法处理数据时,抛出异常或错误;

请求(Request-based):消费者根据自身处理能力向生产者请求数据,生产者只在接收到请求时才发送数据。适用于消费者处理能力波动较大,需要动态调整处理速率的场景。

缓冲示例:

Flux<Integer> source = Flux.range(1, 100);
source.onBackpressureBuffer(10) // 设置缓冲区大小为10.subscribe(System.out::println);

丢弃示例:

Flux<Integer> source = Flux.range(1, 100);
source.onBackpressureDrop(item -> System.out.println("Dropped: " + item)).subscribe(System.out::println);

最新示例:

Flux<Integer> source = Flux.range(1, 100);
source.onBackpressureLatest().subscribe(System.out::println);

错误示例:

Flux<Integer> source = Flux.range(1, 100);
source.onBackpressureError().subscribe(System.out::println,error -> System.err.println("Error: " + error));

请求示例:

Flux<Integer> source = Flux.range(1, 100);
source.subscribe(new BaseSubscriber<Integer>() {@Overrideprotected void hookOnSubscribe(Subscription subscription) {request(1); // 初始请求1个数据}@Overrideprotected void hookOnNext(Integer value) {System.out.println(value);// 每处理完一个数据后再请求一个数据request(1);}
});

这篇关于Spring响应式编程之Reactor背压机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1088403

相关文章

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick