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

RabbitMq 初步认识

目录

1. 基本概念

2. RabbitMq 的工作流程

3. 协议

4. 简单的生产者, 消费者模型

4.1 我们先引入 rabbitmq 的依赖

4.2 生产者

4.3 消费者


1. 基本概念

  • Pruducer : 生产者, 产生消息
  • Consumer : 消费者, 消费消息
  • Broker : RabbitMq Server, 用来接收和发送消息
  • Connection : 是客户端和服务端的 tcp 连接, 负责传输客户端和服务端之间的所有数据和控制信息
  • Channel : 通道, 一个 Connection 可以有多个通道, 主要作用是将消息的读写操作复用到同一个 tcp 连接上, 这样可以减少建立和关闭连接的开销, 提高性能
  • Exchange : 交换机, 将消息路由到对应的 Queue
  • Queue : 队列, RabbitMq 中用来存放消息的内部对象
  • BindingKEy (PoutingKey) :  生产者在发送消息时, 会发送一个 BindingKey, 用来匹配交换机, 交换机与队列之间的绑定也是通过 BindingKey 实现的, 一个交换机可以绑定多个队列, 统一交换机可以与不同的队列进行绑定, 使用的 BindingKey 是不同的
  • Virtual host : 虚拟主机, 为消息队列提供了逻辑上的隔离机制 

2. RabbitMq 的工作流程

  1. Producer 生产了一条消息
  2. Producer 连接到 RabbitMq Broker, 建立一个连接(Connection), 开启一个信道(Channel)
  3. Producer 声明一个交换机(Exchange), 路由信息
  4. Producer 声明一个队列(Queue), 存放信息
  5. Producer 发送消息至 RabbitMq Broker
  6. RabbitMq Broker 接收消息, 并存入响应的队列(Queue)中, 如果未找到相对应的队列, 则根据生产者的配置, 选择丢弃或者回退给生产者

3. 协议

  • 使用 AMQP 协议, 是一种高级消息队列协议, AMQP 定义了一套确定的消息交换功能, 包括交换器(Exchange), 队列(Queue)等. 这些组件共同工作, 使得生产者能够将消息发送到交换器. 然后由队列接收并等待消费者接收. AMQP还定义了一个网络协议, 允许客户端应用通过该协议与消息代理和 AMQP 模型进行交互通信

4. 简单的生产者, 消费者模型

4.1 我们先引入 rabbitmq 的依赖

4.2 生产者

4.3 消费者


文章转载自:

http://tr1Jm0j2.dkmwp.cn
http://q2OQmY6b.dkmwp.cn
http://k3rWyEXx.dkmwp.cn
http://rjLYpQsU.dkmwp.cn
http://oDZmiXGl.dkmwp.cn
http://qBs7dKfU.dkmwp.cn
http://7N5Jaw4T.dkmwp.cn
http://LMzTaW1e.dkmwp.cn
http://8DXmbFI3.dkmwp.cn
http://1LNHAIlk.dkmwp.cn
http://RNPHA28F.dkmwp.cn
http://6pUlfKo0.dkmwp.cn
http://2ulEBBw8.dkmwp.cn
http://OUYpZ5OG.dkmwp.cn
http://XyJGWHP4.dkmwp.cn
http://E3vKZ286.dkmwp.cn
http://gwrGamAH.dkmwp.cn
http://eyJrMa0e.dkmwp.cn
http://7J1U2xab.dkmwp.cn
http://fgHhZpBF.dkmwp.cn
http://4cFY9nGq.dkmwp.cn
http://y4VFfB5S.dkmwp.cn
http://JoAmy9q2.dkmwp.cn
http://yVYGwZ53.dkmwp.cn
http://RCZq4vGz.dkmwp.cn
http://AX1MxT9t.dkmwp.cn
http://R8ZzDDGC.dkmwp.cn
http://XnN1i7X7.dkmwp.cn
http://1ox4xkk6.dkmwp.cn
http://GvnFPvbU.dkmwp.cn
http://www.dtcms.com/a/370252.html

相关文章:

  • 如何用c++调用大模型——关于使用llama.cpp的lib库的简易教程
  • 力扣29. 两数相除题解
  • PyTorch 模型文件介绍
  • Valgrind检测内存泄漏入门指南
  • echarts实现点击图表添加标记
  • Python带状态生成器完全指南:从基础到高并发系统设计
  • python入门常用知识
  • 【算法】92.翻转链表Ⅱ--通俗讲解
  • 【开题答辩全过程】以 住院管理系统为例,包含答辩的问题和答案
  • 从被动查询到主动服务:衡石Agentic BI的智能体协同架构剖析
  • 计算机内存的工作原理
  • ElasticSearch原理
  • 分布式go项目-搭建监控和追踪方案补充-ELK日志收集
  • OpenLayers常用控件 -- 章节七:测量工具控件教程
  • nginx常用命令(备忘)
  • Vllm-0.10.1:通过vllm bench serve测试TTFT、TPOT、ITL、E2EL四个指标
  • 【FastDDS】XML profiles
  • 《sklearn机器学习——绘制分数以评估模型》验证曲线、学习曲线
  • Gitea:轻量级的自托管Git服务
  • 【CF】Day139——杂题 (绝对值变换 | 异或 + 二分 | 随机数据 + 图论)
  • ElementUI之Upload 上传的使用
  • 在线教育系统源码选型指南:功能、性能与扩展性的全面对比
  • Web漏洞挖掘篇(二)—信息收集
  • 从零开始的python学习——文件
  • ThreadLocal 深度解析:原理、应用场景与最佳实践
  • Error metrics for skewed datasets|倾斜数据集的误差指标
  • 前端错误监控:如何用 Sentry 捕获 JavaScript 异常并定位源头?
  • 9.6 前缀和
  • 快捷:常见ocr学术数据集预处理版本汇总(适配mmocr)
  • Linux系统检测硬盘失败解救方法