当前位置: 首页 > news >正文

【RabbitMQ】RabbitMQ如何保证消息不丢失?

为了保证消息不丢失,需要在生产者、RabbitMQ本身和消费者三个环节采取相应措施。

1.生产者端:确保消息发送成功

1.1开启消息确认机制(Publisher Confirms)

  • 原理: 生产者发送消息后,RabbitMQ会返回一个确认(ACK),表示消息已成功接收。

1.2开启事务机制(Transactions)

  • 原理: 生产者发送信息后,可以通过事务机制确保信息被成功接收。
  • 注意: 事务机制性能较低,推荐消息确认机制。

1.3消息持久化

  • 原理: 将消息标记为持久化,确保RabbitMQ重启后消息不会丢失。

2.RabbitMQ端:确保消息可靠存储

2.1队列持久化:

  • 原理: 将队列标记为持久化,确保RabbitMQ重启后队列不会丢失。

2.2交换机持久化:

  • 原理: 将交换机标记为持久化,确保RabbitMQ重启后交换机不会丢失。

2.3镜像队列

  • 原理: 将队列镜像到多个节点,确保即使某个节点宕机,消息也不会丢失。

3.消费者端:确保消息成功处理

3.1手动确认

  • 原理: 消费者在处理完消息后,手动发送确认(ACK)给RabbitMQ,表示消息已成功处理。

3.2消息重试机制:

  • 原理: 如果消息处理失败,可以将消息重新放回队列或转移到私信队列(Dead Letter Queue DLQ)。

3.3死信队列:

  • 原理: 将处理失败的消息转移到死信队列,避免消息丢失。

4.总结:

  • 生产者端: 开启消息确认机制,发送持久化消息。
  • RabbitMQ端: 持久化队列和交换机,使用镜像队列。
  • 消费者端: 开启手动确认机制,实现消费重试或使用死信队列。
http://www.dtcms.com/a/80775.html

相关文章:

  • sqlite3
  • Linux 音频驱动 WM8960 音频 DAC IC 音乐播放与录音
  • 第四周日志-用网络请求理解bp(2)
  • 华为OD机试-会议室占用时间段(Java 2024 C卷 100分)
  • Rust语言学习
  • 体育直播视频源格式解析:M3U8 vs FLV
  • mysql中find_in_set()函数用法详解及增强函数
  • mysql-DELETE、DROP 和 TRUNCATE区别
  • deepSpeed多机多卡训练服务器之间,和服务器内两个GPU是怎么通信
  • Linux 系统性能优化高级全流程指南
  • 免费开源的NAS解决方案:TrueNAS
  • 工厂方法模式、简单工厂模式与抽象工厂模式的对比
  • 正则表达式:文本处理的瑞士军刀
  • 如何在云端平台上建立 30,000 名用户的网页 MMO游戏环境-2 (服务器)
  • 【工业现场总线】控制网络的主要特点是?OSI参考模型的分层是?
  • `chromadb` 是什么
  • hive 数据简介
  • C++通过宏将任何内容转成字符串的方式
  • Git的基本使用
  • linux 添加自定义文件类型,自定义文件图标,自定义类型默认打开应用 启动菜单
  • 强化学习(赵世钰版)-学习笔记(完)(10.Actor-Critic方法)
  • 玩转物联网-4G模块如何快速将数据上传到巴法云(TCP篇)
  • ASP.NET会话攻防战:彻底歼灭会话固定漏洞的六层防御体系
  • Buuctf [极客大挑战 2019]FinalSQL
  • 数仓工具—Hive语法之不同纬度聚合
  • (一)飞行器的姿态欧拉角, 欧拉旋转, 完全数学推导(基于坐标基的变换矩阵).(偏航角,俯仰角,横滚角)
  • 数据结构-----队列
  • QuickAPI:一键将 Excel 数据转为数据库表
  • OpenHarmony子系统开发 - 电池管理(二)
  • 群体智能优化算法-粒子群优化算法(Particle Swarm Optimization, PSO,含Matlab源代码)