RabbitMQ 如何设置限流?

RabbitMQ 的限流(流量控制)主要依赖于 QoS(Quality of Service) 机制,即 prefetch count 参数。这个参数控制每个消费者一次最多能获取多少条未确认的消息,从而避免某个消费者被大量消息压垮。


1. RabbitMQ 限流的主要方式

(1) 基于 prefetch count 进行流量控制

作用:控制 RabbitMQ 一次最多发送多少条消息 给消费者,避免消费者积压太多消息导致内存爆炸。

  • 默认情况下,RabbitMQ 会源源不断地向消费者推送消息,直到消费者崩溃。
  • prefetch count 设为 1,表示消费者一次只获取 1 条消息,处理完再取下一条。

示例(Java Spring Boot 版):

// 生产者 - 用户抢购
public void sendSeckillRequest(String userId, String productId) {String message = userId + "," + productId;rabbitTemplate.convertAndSend("seckillQueue", message);
}// 消费者 - 处理秒杀
@RabbitListener(queues = "seckillQueue", containerFactory = "customContainerFactory")
public void handleSeckillRequest(Message message, Channel channel) throws IOException {try {String msg = new String(message.getBody(), StandardCharsets.UTF_8);System.out.println("收到秒杀请求:" + msg);// 模拟秒杀业务处理Thread.sleep(1000);// 手动ACK,表示消息已消费完成channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);} catch (Exception e) {// 处理失败时拒绝消息,并放回队列channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, true);}
}

对应的RabbitMQ 配置(限制 prefetch count)

@Bean
public SimpleRabbitListenerContainerFactory customContainerFactory(ConnectionFactory connectionFactory) {SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();factory.setConnectionFactory(connectionFactory);factory.setAcknowledgeMode(AcknowledgeMode.MANUAL); // 手动ACKfactory.setPrefetchCount(1); // **每次只取 1 条消息**return factory;
}

这样可以限制 RabbitMQ 一次最多给每个消费者发送 1 条消息,等它处理完了才会发送下一条。


(2) 基于 x-max-length 限制队列长度

作用:限制消息队列的最大长度,超出部分的消息会被丢弃。

示例(Java 代码方式创建队列,并限制最大长度 1000):

@Bean
public Queue seckillQueue() {return QueueBuilder.durable("seckillQueue").withArgument("x-max-length", 1000) // **最多存 1000 条消息**.build();
}

这样,RabbitMQ 最多存 1000 条秒杀请求,超出的会自动丢弃,避免无限堆积。


(3) 基于 x-message-ttl 限制消息存活时间

作用:让 RabbitMQ 的消息有过期时间,超时未消费的消息会被删除。

示例(Java 代码方式):

@Bean
public Queue seckillQueue() {return QueueBuilder.durable("seckillQueue").withArgument("x-message-ttl", 5000) // **5 秒后未消费,自动删除**.build();
}

这样,RabbitMQ 超过 5 秒未消费的消息会自动删除,避免秒杀请求无限堆积。


(4) 基于 x-max-priority 设置优先级队列

作用:高优先级的消息先被消费。

示例(Java 代码方式):

@Bean
public Queue seckillQueue() {return QueueBuilder.durable("seckillQueue").withArgument("x-max-priority", 10) // **优先级范围 0-10**.build();
}

生产者在发送消息时,可以为每条消息指定优先级:

rabbitTemplate.convertAndSend("seckillQueue", "普通用户秒杀请求", message -> {message.getMessageProperties().setPriority(1); // 普通用户优先级低return message;
});rabbitTemplate.convertAndSend("seckillQueue", "VIP 用户秒杀请求", message -> {message.getMessageProperties().setPriority(9); // VIP 用户优先级高return message;
});

优先级范围:0~10(具体取决于队列的 x-max-priority 设置)。

  • 0 表示最低优先级
  • 10 表示最高优先级
  • RabbitMQ 会优先发送高优先级的消息给消费者。

这样,RabbitMQ 支持优先级消息,比如可以让 VIP 用户的秒杀请求优先处理。


2. 结合多个限流策略优化秒杀系统

高并发秒杀场景下,RabbitMQ 限流可以这样设计:

限流方式作用
prefetch count = 1限制消费者一次最多消费 1 条消息,防止消息处理过载。
x-max-length = 1000限制队列最大存储 1000 条消息,超出的直接丢弃,防止消息堆积。
x-message-ttl = 5000超过 5 秒未消费的秒杀请求自动删除,避免系统长时间积压请求。
x-max-priority = 10支持优先级消息,比如 VIP 用户的消息先消费。

这样能有效防止 RabbitMQ 队列爆炸,保护数据库,提升秒杀成功率


3. 总结

基于 prefetch count 限制消费速率,防止消费者被消息压垮。
基于 x-max-length 限制队列最大长度,防止秒杀请求无限堆积。
基于 x-message-ttl 让过期消息自动删除,避免长时间存积压请求。
基于 x-max-priority 提高 VIP 用户的处理优先级,提升体验。

这些策略组合使用,可以大幅提升RabbitMQ 在秒杀系统中的稳定性和吞吐能力 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/16343.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity3D实现显示模型线框(shader)

系列文章目录 unity工具 文章目录 系列文章目录👉前言👉一、效果展示👉二、第一种方式👉二、第二种方式👉壁纸分享👉总结👉前言 在 Unity 中显示物体线框主要基于图形渲染管线和特定的渲染模式。 要显示物体的线框,通常有两种常见的方法:一种是利用内置的渲染…

活动预告 |【Part1】Microsoft Azure 在线技术公开课:AI 基础知识

课程介绍 参加“Azure 在线技术公开课:AI 基础知识”活动,了解 AI 核心概念。参加我们举办的本次免费培训活动,了解组织如何使用 AI 技术克服实际挑战,以及如何借助 Azure AI 服务构建智能应用程序。本次培训适用于任何对 AI 解决…

Hello Robot 推出Stretch 3移动操作机器人,赋能研究与商业应用

Hello Robot公司近日发布了其新一代开源移动操作机器人Stretch 3,这是一款高度灵活的机器人平台,专为机器人研究、教育实验和商业自动化设计。Stretch 3 结合了先进的移动机器人技术、灵巧操作能力和开源软件生态系统,为用户提供了一个功能强…

题解 洛谷 Luogu P1828 [USACO3.2] 香甜的黄油 Sweet Butter 最短路 堆优化Dijkstra Floyd C++

题目 传送门 P1828 [USACO3.2] 香甜的黄油 Sweet Butter - 洛谷 | 计算机科学教育新生态https://www.luogu.com.cn/problem/P1828 思路 以每头奶牛所在的牧场为起点,求得到全图各个点的最短距离 再枚举全图所有点,计算从所有起点到某点的距离之和&a…

堆排序

目录 堆排序(不稳定): 代码实现: 思路分析: 总结: 堆排序(不稳定): 如果想要一段数据从小到大进行排序,则要先建立大根堆,因为这样每次堆顶上都能…

2.11日学习总结

题目一 &#xff1a; AC代码 #include <stdio.h> #include <stdlib.h>// 定义长整型 typedef long long ll;// 定义求最大值和最小值的宏函数 #define MAX(a, b) ((a) > (b) ? (a) : (b)) #define MIN(a, b) ((a) < (b) ? (a) : (b))// 定义数组和变量 ll…

Ollama 简单 好用 好玩

简介 Ollama https://github.com/ollama/ollama/ 是一个基于 Go 语言 的 本地大语言模型运行框架&#xff0c;专注于本地化运行大型语言模型&#xff08;LLM&#xff09;的开源工具。 类 Docker 产品&#xff08;支持 list,pull,push,run 等命令&#xff09;&#xff0c;更好玩…

【AIGC】在VSCode中集成 DeepSeek(OPEN AI同理)

在VSCode中集成 DeepSeek&#xff08;OPEN AI同理&#xff09; 一、集成 DeepSeek二、其他推荐VSCode插件 在 Visual Studio Code (VSCode) 中集成 AI 编程能力&#xff0c;可以通过安装和配置特定插件来实现。以下是如何通过 Continue 和 Cline 插件集成 DeepSeek&#xff1a;…

SpringBootWeb三层架构分层解耦

SpringBootWeb 1. SpringBootWeb案例1.1 控制层未拆分代码1.2 实体类1.3 静态资源文件1.4 txt文件1.5 运行界面展示 2. 三层架构拆分2.1 控制层&#xff08;Controller&#xff09;2.1.1 功能2.1.2 用户信息控制层 2.2 业务逻辑层&#xff08;Service&#xff09;2.2.2 功能2.2…

MyBatis的工作流程是怎样的?

大家好&#xff0c;我是锋哥。今天分享关于【MyBatis的工作流程是怎样的&#xff1f;】面试题。希望对大家有帮助&#xff1b; MyBatis的工作流程是怎样的&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 MyBatis 的工作流程可以分为几个主要的步骤&…

carbon 加入 GitCode:Golang 时间处理的 “瑞士军刀”

在 Golang 的开发生态中&#xff0c;时间处理领域长期存在着诸多挑战。高效、精准的时间处理对于各类软件应用的稳定运行与功能拓展至关重要。近日&#xff0c;carbon 正式加入 GitCode&#xff0c;为 Golang 开发者带来一款强大且便捷的时间处理利器&#xff0c;助力项目开发迈…

【力扣】148.排序链表

AC截图 题目 思路 基本情况处理&#xff1a; 如果链表为空 (head NULL) 或者链表仅有一个节点 (head->next NULL)&#xff0c;则链表已经是有序的&#xff0c;直接返回头节点 head。 分割链表&#xff1a; 使用快慢指针法找到链表的中间节点。slow 指针每次前进一格&…

新数据结构(7)——Object

Object类是所有类的父类&#xff0c;也就是说所有类都是object类的子类可以使用Object里的方法。 equals()和hashCode()是Object包含的方法 和equals的区别和联系 和equals()都是用于判断是否相等 基本数据类型只能用判断其是否相等&#xff0c;引用数据类型用判断的是其指…

保研考研机试攻略:python笔记(4)

🐨🐨🐨15各类查找 🐼🐼二分法 在我们写程序之前,我们要定义好边界,主要是考虑区间边界的闭开问题。 🐶1、左闭右闭 # 左闭右闭 def search(li, target): h = len(li) - 1l = 0#因为都是闭区间,h和l都可以取到并且相等while h >= l:mid = l + (h - l) // 2…

doris集群

开发doris的团队厉害&#xff0c;这个百度工程师确实也干了一些实事&#xff0c;不像领导层只会跑火车。 1 参数配置 1.1 文件句柄数 vim /etc/security/limits.conf * soft nofile 655350 * hard nofile 6553501.2 关闭透明大页 echo never > /sys/kernel/mm/transpare…

STM32的HAL库开发---高级定时器---互补输出带死区实验

一、互补输出简介 互补输出&#xff1a;OCx输出高电平&#xff0c;则互补通道OCxN输出低电平。OCx输出低电平&#xff0c;则互补通道OCxN输出高电平。 带死区控制的互补输出&#xff1a;OCx输出高电平时&#xff0c;则互补通道OCxN过一会再输出输出低电平。这个时间里输出的电…

京东广告生成式召回基于 NVIDIA TensorRT-LLM 的推理加速实践

0000 生成式推荐系统优势介绍 推荐系统的主要任务是根据用户的历史行为预测其兴趣点&#xff0c;并向其推荐相应的商品。传统的推荐系统在处理用户请求时&#xff0c;会触发多个召回模块&#xff08;包括热门商品召回、个性化召回、深度召回等&#xff09;&#xff0c;以召回大…

3.React 组件化开发

react&#xff1a;版本 18.2.0node&#xff1a; 版本18.19.1脚手架&#xff1a;版本 5.0.1 一、类组件 (一) 一个干净的脚手架 【1】使用已经被废弃的 CRA (create-react-app) create-react-app 已经被废弃&#xff0c;且目前使用会报错&#xff0c;官方已经不推荐使用&…

51单片机(国信长天)矩阵键盘的基本操作

在CT107D单片机综合训练平台上&#xff0c;首先将J5处的跳帽接到1~2引脚&#xff0c;使按键S4~S19按键组成4X4的矩阵键盘。在扫描按键的过程中&#xff0c;发现有按键触发信号后(不做去抖动)&#xff0c;待按键松开后&#xff0c;在数码管的第一位显示相应的数字:从左至右&…

【AI赋能】蓝耘智算平台实战指南:3步构建企业级DeepSeek智能助手

蓝耘智算平台实战指南&#xff1a;3步构建企业级DeepSeek智能助手 引言&#xff1a;AI大模型时代的算力革命 在2025年全球AI技术峰会上&#xff0c;DeepSeek-R1凭借其开源架构与实时推理能力&#xff0c;成为首个通过图灵测试的中文大模型。该模型在语言理解、跨模态交互等维…