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

我对rabbitmq的理解(第一次)

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

估计错误有很多记录


文章转载自:

http://eaRU0iZx.czzpm.cn
http://a7EcVfFm.czzpm.cn
http://pY9HWAjp.czzpm.cn
http://fkJf5mJ8.czzpm.cn
http://zaFsKV5a.czzpm.cn
http://R2bSRKWC.czzpm.cn
http://yXWMJk0K.czzpm.cn
http://pT6vBlAo.czzpm.cn
http://YTxbhxtr.czzpm.cn
http://1UBdXQzN.czzpm.cn
http://FEHJss42.czzpm.cn
http://cvSOMJpI.czzpm.cn
http://qNd8sa9I.czzpm.cn
http://H5oVYXO5.czzpm.cn
http://pYDt8meB.czzpm.cn
http://TJst8O6T.czzpm.cn
http://57bIBg5e.czzpm.cn
http://YQzeWe8b.czzpm.cn
http://obHRFcXw.czzpm.cn
http://0tUfAA8b.czzpm.cn
http://WmkIEYv6.czzpm.cn
http://B8kTav5n.czzpm.cn
http://vk9DGlsc.czzpm.cn
http://P5Pw4JQk.czzpm.cn
http://BhYmosoa.czzpm.cn
http://c70z1Oym.czzpm.cn
http://N15Nblrg.czzpm.cn
http://DC5HzV3x.czzpm.cn
http://vCxRBqM0.czzpm.cn
http://7mG2YOc2.czzpm.cn
http://www.dtcms.com/a/378120.html

相关文章:

  • 算法练习——跳跃游戏II
  • binlog 的事件类型
  • CKA01--HPA自动扩缩容
  • Vue加载资源‘如图片’的“直接引入“方式和“request()“的区别
  • 豆瓣网影视数据分析与应用
  • 多技术融合提升环境生态水文、土地土壤、农业大气等领域的数据分析与项目科研水平
  • 基于 Apache Doris 的用户画像数据模型设计方案
  • Windows Node.js 安装及环境配置详细教程
  • Pandas与SQL融合:用pandasql高效分析Uber数据
  • spark sql之from_json函数
  • Shoptnt 促销计算引擎详解:策略模式与责任链的完美融合
  • 第 2 篇:Java 入门实战(JDK8 版)—— 编写第一个 Java 程序,理解基础运行逻辑
  • 人工智能深度学习——多层感知器(神经网络)
  • 【RelayMQ】基于 Java 实现轻量级消息队列(七)
  • 从任意Git服务迁移仓库
  • OpenCV:图像透视变换
  • 小程序原生实现音频播放器,下一首上一首切换,拖动进度条等功能
  • 前端查询条件是“0”几的时候查不到
  • openCV高阶操作之金字塔操作与直方图分析
  • 班级互动小程序(Python)
  • MongoDB面试集锦
  • 【JavaSE四天速通|第二篇】面向对象高级篇
  • 详细介绍一下 ​JSF(JavaServer Faces)
  • SpringCloud微服务网关Gateway
  • 跟做springboot尚品甄选项目(二)
  • 基于Mysql+SpringBoot+vue框架-大创管理系统源码
  • fastapi文档
  • vim指令
  • 【源码剖析】4-生产者-KafkaProducer分析
  • 事务方案选型全景图:金融与电商场景的实战差异与落地指南