我对rabbitmq的理解(第一次)

众所周知rabbitmq是一个中间件,作用呢是帮助系统高效处理消息,解决了传统项目复杂业务(多个非核心操作)串行同步,带来的响应时间长,容错能力低,耦合性高。它实现了AMQP协议高级消息队列协议。

如何解决这三个问题(异步处理机制,消息重试机制,设计解耦)

异步处理机制(系统处理完核心操作就给使用者反馈触发生产者将非核心操作(失败不会影响业务核心功能),发送到消息队列,让消费者根据自身情况处理)

消息重试机制(当消息发送给消费者,消费者迟迟不返回ACK消息,则重复几次还是没有->死信队列人工处理)

设计解耦(消费者错误或修改不影响其他角色)

主要包含 生产者 , 消费者 ,交换机 ,消息队列 四个角色展开活动

消息的传递过程 生产者->交换机->消息队列->消费者

实际业务使用 生产者产生消息并发送给交换机,交换机根据消息中的路由键来判断发送给哪一个消息队列,消费者监听消息队列从而获取消息并且消费消息。

那么其中关撬有很多了,消息在传递过程中丢失了咋办?消息队列占满了咋办?消息一直在消息队列中不管是不是被消费?消费者获取到信息消费失败咋办?rabbitmq容器宕机了咋办?

第一个问题:如何识别消息被接收成功以及触发重新发送 主要是这个 生产者->交换机->消息队列过程

第二个问题:消息队列的删除机制

第三个问题:不是,消息被消费完成,消费者会给队列发送ACK消息,队列收到该消息把对应的消息删除

第四个问题:消息重试,当队列迟迟没有收到ACK消息,重新发送消息给指定消费者

第五个问题:消息以及交换机配置信息持久化

这几个问题就是rabbitmq,设计的核心所在

注意消费者不是系统的使用者,而是监听和处理消息的一个类。

使用者只是业务的触发者。

估计错误有很多记录

相关推荐
止语Lab1 天前
一次 goroutine 泄漏:pprof 说有 10 万个 goroutine,但问题不在 channel
rabbitmq
JLWcai2025100916 天前
铸造领域树脂砂轮|金利威多场景解决方案,20 + 配方覆盖全需求
mongodb·zookeeper·eureka·spark·rabbitmq·memcached·storm
风吹夏回16 天前
RabbitMQ 核心术语 + Python pika 方法完整讲解
分布式·python·rabbitmq
风吹夏回16 天前
RabbitMQ 三种模式入门:HelloWorld、WorkQueue、PubSub
分布式·rabbitmq·ruby
霸道流氓气质16 天前
分布式追踪与 RequestId 传播完全指南
分布式
cheems952716 天前
[RabbitMQ高级特性] 消息确认机制:从 Ready / Unacked 到 basicAck、basicReject、basicNack 的底层拆解
分布式·rabbitmq·ruby
枫华落尽16 天前
【Hadoop01-完全分布式运行模式】
分布式
隔壁阿布都16 天前
ShedLock 分布式定时任务锁框架介绍
spring boot·分布式
文艺倾年16 天前
【强化学习】数学推导专题,20W字总结(十五)
人工智能·分布式·大模型·强化学习·vibecoding
ACP广源盛1392462567316 天前
GSV9001S@ACP#1080P 级视频处理芯片,物理 AI 普及终端的高性价比选择
大数据·人工智能·分布式·嵌入式硬件·spark