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

理解 RabbitMQ:生产者、连接、通道、交换机、队列与消费者的消息流

在分布式消息系统中,RabbitMQ 是一个非常流行的消息代理。它的核心理念是解耦应用程序的生产者和消费者,使得消息能够可靠地从一方传递到另一方。本文将带你深入了解 RabbitMQ 中 生产者连接通道交换机队列消费者 之间的消息流,并解释各个组件的作用。

1. 生产者(Producer)

生产者是消息的发送者。在 RabbitMQ 中,生产者的任务是创建并发布消息到 RabbitMQ。消息不会直接进入队列,而是通过交换机(Exchange)来进行路由。通常情况下,生产者与 RabbitMQ 的交互过程如下:

  1. 建立 连接(Connection)。
  2. 打开 通道(Channel)。
  3. 将消息发布到 交换机(Exchange)。

在多数场景下,生产者不需要保持长时间的连接。生产者可以在需要发布消息时创建连接,发送完消息后关闭连接。

2. 连接(Connection)

RabbitMQ 的连接是客户端和 RabbitMQ 服务器之间的 TCP 连接。一个客户端通过连接与 RabbitMQ 通信,通常生产者和消费者都会先建立一个连接。

  • 资源消耗:每个连接都消耗一定的系统资源。如果每个客户端都保持长时间连接,当并发量很大时,会造成资源浪费。
  • 多通道复用:为了减少系统资源的开销,RabbitMQ 支持多个通道共享一个连接,这大大降低了高并发场景下的资源占用。

3. 通道(Channel)

通道是基于 连接 之上的虚拟通信路径。一个连接可以创建多个通道,RabbitMQ 通过通道来执行具体的操作(例如,发送消息、接收消息等)。通道的存在避免了频繁创建和关闭连接的开销。

  • 轻量级:通道是轻量级的,可以在同一个 TCP 连接上创建多个通道。
  • 线程安全:多个线程可以通过不同的通道并发地与 RabbitMQ 交互,但需要确保每个线程使用一个单独的通道。

4. 交换机(Exchange)

生产者将消息发送到交换机,交换机负责将消息路由到一个或多个队列。交换机通过 routing key绑定(Binding) 将消息正确分发。

  • Direct 交换机:根据消息的 routing key 精确匹配队列。
  • Fanout 交换机:将消息广播到所有绑定到此交换机的队列。
  • Topic 交换机:支持基于 routing key 模式的模糊匹配,将消息路由到符合匹配规则的队列。
  • Headers 交换机:根据消息头中的属性路由消息。

交换机可以灵活地控制消息的流向,使得 RabbitMQ 在复杂场景下能够处理多种不同类型的消息流动。

5. 队列(Queue)

队列是存储消息的容器。消费者从队列中提取消息并进行处理。队列中的消息是按照先进先出的顺序被处理的,消息一旦进入队列,除非被消费,否则不会丢失。

  • 消息持久化:队列可以配置为持久化模式,这样即使 RabbitMQ 重启,队列中的消息也不会丢失。
  • 多个消费者:同一个队列可以被多个消费者监听,RabbitMQ 会将消息负载均衡地分发给不同的消费者。

6. 消费者(Consumer)

消费者从 RabbitMQ 中接收并处理消息。通常消费者会:

  1. 建立 连接
  2. 打开 通道
  3. 从指定的 队列 中消费消息。

消费者可以是多个,RabbitMQ 支持将队列中的消息负载均衡地分发给多个消费者,确保每个消息只会被一个消费者处理。


RabbitMQ 消息流动的整体流程

  1. 生产者 创建一个消息并发送到 交换机
  2. 交换机 根据绑定规则(通过 routing key)将消息路由到相应的 队列
  3. 消费者 从队列中获取消息并处理。

简化的消息流示意图如下:
 

  [ Producer ] | (1)v[ Connection ] --(2)--> [ Channel ] --(3)--> [ Exchange ]|v+------------- Routing -------------+|                                    |[ Queue 1 ]                          [ Queue 2 ]|                                    |v                                    v[ Consumer A ]                       [ Consumer B ]
  1. Producer 通过 Connection 发送消息,消息进入 Channel
  2. Channel 将消息发送给 Exchange
  3. Exchange 根据路由规则将消息分发到不同的 Queue
  4. Consumer 从队列中获取并处理消息。

各个组件的作用总结

  • 生产者(Producer):发送消息的一方。通常在需要时建立连接,不保持长时间连接。
  • 连接(Connection):生产者和消费者与 RabbitMQ 之间的物理 TCP 连接。多个通道可以复用一个连接,减少资源消耗。
  • 通道(Channel):轻量级的虚拟通信路径,用于执行消息的发送和接收操作。
  • 交换机(Exchange):负责根据绑定规则将消息路由到不同的队列,确保消息能够正确分发。
  • 队列(Queue):存储消息的容器,等待消费者提取和处理消息。
  • 消费者(Consumer):从队列中消费消息的程序。

生产者与消费者的连接管理

生产者通常不需要保持长时间的连接。最佳实践是在消息发布时重新建立连接,然后发布消息,之后关闭连接。这种按需连接的方式可以减少资源的占用,避免长时间空闲连接导致的断开问题。

消费者通常需要保持长时间的连接以监听队列中的消息。这时可以使用心跳机制来确保连接的活跃性,防止连接因空闲而被关闭。

相关文章:

理解 RabbitMQ:生产者、连接、通道、交换机、队列与消费者的消息流

在分布式消息系统中,RabbitMQ 是一个非常流行的消息代理。它的核心理念是解耦应用程序的生产者和消费者,使得消息能够可靠地从一方传递到另一方。本文将带你深入了解 RabbitMQ 中 生产者、连接、通道、交换机、队列 和 消费者 之间的消息流,并…...

【截图服务 +打包】pkg打包 puppeteer

目录 最后结论 windows打包成服务 定制executablePath 服务遇到的问题 使用java开一个线程启动 遇到的问题与解决 版本匹配问题 打出包后的运行报错问题 linux下的安装 安装n 库缺少 程序运行后的报错 制作 运行报错与修改后成功 参考文档 最后结论 pkg -t win…...

深入理解Servlet的并发处理机制小波制图流程图

在Java Web开发中,Servlet是处理HTTP请求的核心组件。理解Servlet如何处理并发请求对于开发高性能Web应用至关重要。本文将深入探讨Servlet的生命周期、实例化过程以及多线程处理机制。 Servlet的生命周期和实例化 Servlet遵循单例模式,对于每个Servle…...

Ajax和XMLHttpRequest之间的关系

Ajax和XMLHttpRequest之间的关系是非常密切的。Ajax(Asynchronous JavaScript and XML)是一种网页开发技术,用于创建交互式的应用程序或网站。而XMLHttpRequest是Ajax的核心技术之一。 XMLHttpRequest:这是一个JavaScript对象&…...

Linxu系统:kill命令

1、命令详解: kill命令是用于向进程发送信号,通常用来终止某个指定PID服务进程,kill命令可以发送不同的信号给目标进程,来实现不同的操作,如果不指定信号,默认会发送 TERM 信号(15)&…...

解决缺少genconfig

编译鸿蒙L0系统时,遇到报错: [OHOS INFO] Returned 127. [OHOS INFO] stderr: [OHOS INFO] [OHOS INFO] env: “genconfig”: 没有那个文件或目录 [OHOS INFO] [OHOS INFO] See //kernel/liteos_m/BUILD.gn:34:1: whence it was imported. [OHOS INFO] …...

百易云资产管理运营系统 house.save.php SQL注入漏洞

1 产品简介 百易云资产管理运营系统,是专门针对企业不动产资产管理和运营需求而设计的一套综合解决方案。该系统能够覆盖资产的全生命周期管理,包括资产的登记、盘点、评估、处置等多个环节,同时提供强大的运营分析功能,帮助企业…...

【安卓13 源码】Input子系统(3) - EventHub增加设备的流程

由前面的分析知道,在创建inputreader 线程的时候,会去循环执行 looponce 方法。主要的处理工作是: 通过 getEvents() 从 EventHub 获取未处理的事件,这些事件分为两类:一类是原始输入事 件即从设备节点中读取出的原始…...

基于JAVA+SpringBoot+Vue的网上商城系统的设计与实现

基于JAVASpringBootVue的网上商城系统的设计与实现 前言 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN[新星计划]导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末附源码下载链接&#x1…...

Mysql基础练习题 1729.求关注者的数量 (力扣)

编写解决方案,对于每一个用户,返回该用户的关注者数量。 #按 user_id 的顺序返回结果表 题目链接: https://leetcode.cn/problems/find-followers-count/description/ 建表插入语句: Create table If Not Exists Followers(us…...

【鸿蒙HarmonyOS NEXT】页面和自定义组件生命周期

【鸿蒙HarmonyOS NEXT】页面和自定义组件生命周期 一、环境说明二、页面和自定义组件生命周期三、示例代码加以说明四、小结 一、环境说明 DevEco Studio 版本: API版本:以12为主 二、页面和自定义组件生命周期 需要明确几个概念: 页面…...

Node.js Express 框架

Node.js Express 框架 介绍 Express 是一个快速、开放、极简的 Node.js Web 框架。它为构建 Web 应用程序和服务提供了一个强大的工具集,使得开发过程更加高效和便捷。Express 的设计哲学是提供一个最小的 API,让开发者可以轻松地构建自定义的 Web 应用程序。它被广泛用于构…...

生日贺卡录放音芯片,多段音频录音ic生产厂商,NVF04M-32minute

可以录音播放的生日贺卡与传统的纸质贺卡相比,它有着创意以及个性的特点,仅需少量的电子元器件,即可实现录音功能,搭配上文字,让声音存储在生日贺卡里,让贺卡也变得有温度,祝福我想亲口对TA说。…...

电影《西施新传》首映礼,九月金秋全国正式公映

2024年9月1日,古装谋略情感影片《西施新传》在无锡大世界影城中山路IMAX激光店举办首映礼。电影《西施新传》根据作家沈雅琴、笔名一蝶的同名小说改编,以家喻户晓四大美人之首的西施为主人公,讲述了春秋末期吴越战争的故事。越国败于吴国&…...

【H2O2|全栈】关于CSS(1)CSS基础(一)

目录 CSS基础知识 前言 准备工作 啥是CSS? 如何引用CSS? 选择器 通配符选择器 类名(class)选择器 id选择器 CSS解析顺序(优先级) 常见CSS标签(一) 字体属性 font-style…...

动态规划算法之背包问题详细解读(附带Java代码解读)

动态规划中的背包问题(Knapsack Problem)是经典问题之一,通常用来解决选择一组物品放入背包使得背包的价值最大化的问题。根据问题条件的不同,背包问题有很多种变体,如0-1背包问题、完全背包问题、多重背包问题等。这里…...

Vue3+TypeScript二次封装axios

安装如下 npm install axios 第一步:创建config配置文件,用于存放请求后端的ip地址,用于后期打包后便于修改ip地址。 注:typescript要求参数要有类型。(ES6 定义对象 属性 类型 修改的是属性的值) inte…...

华为 HCIP-Datacom H12-821 题库 (16)

有需要题库的可以加下方Q群 V群进行学习交流 1. OSPF 邻居关系建立出现故障,通过 display ospf error 命令来检查,输出结果如图所示,根据图中内容分析,邻居建立失败的原因可能是以下哪一项? A、Process ID 不一致 B、…...

【论文分享精炼版】 sNPU: Trusted Execution Environments on Integrated NPUs

今天在COMPASS分享了之前写的一个博客,做了进一步的提炼总结,大家可以看看原文~ 今天分享的论文《sNPU: Trusted Execution Environments on Integrated NPUs》来自2024年ISCA,共同一作为Erhu Feng以及Dahu Feng。并且, 这两位作…...

MyBatis 入门之动态 SQL

文章目录 一、什么是动态 SQL二、MyBatis 中的动态 SQL 标签三、动态 SQL 的使用示例四、总结 在 Java 开发中,MyBatis 是一个非常流行的持久层框架,它提供了强大的 SQL 映射功能和动态 SQL 支持。动态 SQL 可以根据不同的条件动态地生成 SQL 语句&#…...

JavaSec-RCE

简介 RCE(Remote Code Execution),可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景:Groovy代码注入 Groovy是一种基于JVM的动态语言,语法简洁,支持闭包、动态类型和Java互操作性&#xff0c…...

云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?

大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...

(十)学生端搭建

本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...

简易版抽奖活动的设计技术方案

1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

376. Wiggle Subsequence

376. Wiggle Subsequence 代码 class Solution { public:int wiggleMaxLength(vector<int>& nums) {int n nums.size();int res 1;int prediff 0;int curdiff 0;for(int i 0;i < n-1;i){curdiff nums[i1] - nums[i];if( (prediff > 0 && curdif…...

Vue2 第一节_Vue2上手_插值表达式{{}}_访问数据和修改数据_Vue开发者工具

文章目录 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染2. 插值表达式{{}}3. 访问数据和修改数据4. vue响应式5. Vue开发者工具--方便调试 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染 准备容器引包创建Vue实例 new Vue()指定配置项 ->渲染数据 准备一个容器,例如: …...

(二)原型模式

原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序

一、开发环境准备 ​​工具安装​​&#xff1a; 下载安装DevEco Studio 4.0&#xff08;支持HarmonyOS 5&#xff09;配置HarmonyOS SDK 5.0确保Node.js版本≥14 ​​项目初始化​​&#xff1a; ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...

数据链路层的主要功能是什么

数据链路层&#xff08;OSI模型第2层&#xff09;的核心功能是在相邻网络节点&#xff08;如交换机、主机&#xff09;间提供可靠的数据帧传输服务&#xff0c;主要职责包括&#xff1a; &#x1f511; 核心功能详解&#xff1a; 帧封装与解封装 封装&#xff1a; 将网络层下发…...

高考志愿填报管理系统---开发介绍

高考志愿填报管理系统是一款专为教育机构、学校和教师设计的学生信息管理和志愿填报辅助平台。系统基于Django框架开发&#xff0c;采用现代化的Web技术&#xff0c;为教育工作者提供高效、安全、便捷的学生管理解决方案。 ## &#x1f4cb; 系统概述 ### &#x1f3af; 系统定…...