【MQ篇】RabbitMQ之简单模式!

在这里插入图片描述

目录

    • 引言
    • 一、 初识 RabbitMQ 与工作模式
    • 二、 简单模式 (Simple Queue) 详解:最直接的“点对点快递” 📮
    • 三、 Java (Spring Boot) 代码实战:让小兔子跑起来! 🐰🏃‍♂️
    • 四、 深入理解:简单模式的幕后功臣 🕵️‍♂️
    • 五、 简单模式的局限性与进阶 🤔
    • 六、 总结:简单而不平凡的开始 🎉

🌟我的其他文章也讲解的比较有趣😁,如果喜欢博主的讲解方式,可以多多支持一下,感谢🤗!

🌟了解 MQ 请看 : 【MQ篇】初识MQ!

其他优质专栏: 【🎇SpringBoot】【🎉多线程】【🎨Redis】【✨设计模式专栏(已完结)】…等

如果喜欢作者的讲解方式,可以点赞收藏加关注,你的支持就是我的动力
✨更多文章请看个人主页: 码熔burning

引言

在分布式系统的世界里,消息传递扮演着至关重要的角色。RabbitMQ 作为一款流行的开源消息队列中间件,以其可靠性、灵活性和易用性赢得了广大开发者的青睐。在 RabbitMQ 的众多工作模式中,“简单模式”(Simple Queue)是最基础也是最核心的概念。本文将带你深入了解 RabbitMQ 的简单模式,通过生动的比喻和详尽的 Java (Spring Boot) 代码示例,让你彻底掌握这只勤劳小兔子的极简快递服务!📦➡️🚶‍♀️

RabbitMQ初体验请看(里面有安装步骤):【MQ篇】RabbitMQ初体验!

一、 初识 RabbitMQ 与工作模式

  1. 什么是 RabbitMQ?—— 消息传递的“快递公司” 🏢
    回顾一下我们之前的幽默比喻:RabbitMQ 就像一家高效可靠的“快递公司”,负责在不同的应用程序(“寄件人”和“收件人”)之间传递“包裹”(消息)。它确保消息能够安全、可靠地送达目的地,而无需应用程序之间直接耦合。👍

  2. RabbitMQ 的工作模式:小兔子的多种“送货方式” 🚚
    RabbitMQ 提供了多种工作模式,以适应不同的消息传递场景。每种模式都像小兔子采用不同的“送货方式”来应对不同的需求。简单模式是其中最直接的一种,也是我们理解其他更复杂模式的基础。🚶‍♂️

二、 简单模式 (Simple Queue) 详解:最直接的“点对点快递” 📮

  1. 概念:消息传递的“单行道” 🛣️
    简单模式就像一条单行道,消息从一个生产者直接发送到一个特定的队列,然后被一个或多个消费者接收和处理。它是 RabbitMQ 中最直接、最基础的消息传递方式。
    在这里插入图片描述

  2. 角色:快递服务中的关键参与者 🧑‍💼📦🧑‍💻

    • 生产者 (Producer): 消息的发送者,它创建消息并将其发送到指定的队列。就像寄件人,打包好“包裹”准备寄出。✍️
    • 队列 (Queue): 消息的容器,用于存储等待被消费者处理的消息。它就像快递公司的“中转站” 🏢 或你家门口的“信箱” 📬。
    • 消费者 (Consumer): 消息的接收者,它连接到队列并从中获取消息进行处理。就像收件人,等待着接收自己的“包裹”。😊
  3. 工作流程:消息是怎样“送达”的? 流程图可以更清晰哦!

    • 连接 (Connect): 生产者和消费者首先需要与 RabbitMQ 服务器建立连接,就像去快递公司寄件 🚶‍♂️ 或等待快递员上门 🚶‍♀️。🔗
    • 声明队列 (Declare Queue): 生产者和消费者都需要声明他们将要使用的队列。如果队列不存在,RabbitMQ 会创建它。如果队列已存在,声明操作不会有任何影响。这就像告诉快递公司你要寄往哪个地址 📍,或者你住在哪个地址 🏠。
    • 发送消息 (Publish): 生产者创建消息,并将其发送到指定的队列。在简单模式下,消息直接投递到队列,不需要指定交换机。✉️➡️📦
    • 接收消息 (Consume): 消费者订阅指定的队列,一旦有新消息到达,RabbitMQ 会将消息推送给消费者。👂
    • 处理消息 (Process): 消费者接收到消息后,执行相应的业务逻辑。💻
    • 确认 (Acknowledge): 为了保证消息的可靠性,消费者在成功处理消息后通常会向 RabbitMQ 发送确认。✅
  4. 核心特点:简单、直接、可靠 👍

    • 简单性: 消息直接从生产者到队列,再到消费者,没有复杂的路由规则。 সরল
    • 直接性: 生产者明确指定消息要发送到的队列。 ➡️📦
    • 可靠性: 通过队列的存储和消费者的确认机制,保证消息不会丢失(在适当的配置下)。 安心
  5. 适用场景:简单任务处理的“直通车” 🚀
    简单模式适用于对消息传递的实时性要求不高,且只需要简单的一对一或一对多(但每个消息只被一个消费者处理)的任务处理场景,例如:

    • 发送欢迎邮件。📧
    • 处理用户上传的文件。 📂
    • 执行简单的后台任务。 ⏱️
    • 记录应用程序日志。 📝

三、 Java (Spring Boot) 代码实战:让小兔子跑起来! 🐰🏃‍♂️

接下来,我们通过一个基于 Spring Boot 的 Java 示例,来演示 RabbitMQ 简单模式的实际应用。

  1. 项目依赖 (pom.xml):
    首先,在你的 pom.xml 文件中引入 Spring AMQP 的依赖:

    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId>
    </dependency>
    
  2. RabbitMQ 连接配置 (application.properties):
    配置 RabbitMQ 的连接信息:

    spring:rabbitmq:host: 写你部署的主机ip地址port: 5672username: guestpassword: guest
    
  3. 生产者 (MessageSender.java):
    创建一个发送消息的服务组件:

    import org.springframework.amqp.rabbit.core.RabbitTemplate;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;@Service
    public class MessageSender {@Autowiredprivate RabbitTemplate rabbitTemplate;private static final String QUEUE_NAME = "basic.queue"; // 定义队列名称 🏷️public void sendMessage(String message) {System.out.println(" [Producer] Sending: " + message + " to " + QUEUE_NAME + " ➡️📦");rabbitTemplate.convertAndSend(QUEUE_NAME, message);System.out.println(" [Producer] Message sent! ✅");}
    }
    
  4. 消费者 (MessageReceiver.java):
    创建一个接收消息的组件:

    import org.springframework.amqp.rabbit.annotation.RabbitListener;
    import org.springframework.stereotype.Component;@Component
    public class MessageReceiver {@RabbitListener(queues = "basic.queue") // 监听 "basic.queue" 队列 👂public void receiveMessage(String message) {System.out.println(" [Consumer] Received: " + message + " from " + "basic.queue" + " 📥");try {Thread.sleep(1000); // 模拟处理时间 ⏳} catch (InterruptedException e) {Thread.currentThread().interrupt();}System.out.println(" [Consumer] Done processing: " + message + " 👍");}
    }
    
  5. 启动和测试 (RabbitmqSimpleDemoApplication.java):
    在你的 Spring Boot 主类中注入 MessageSender 并发送消息:

    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.boot.CommandLineRunner;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
    public class RabbitmqSimpleDemoApplication implements CommandLineRunner {@Autowiredprivate MessageSender sender;public static void main(String[] args) {SpringApplication.run(RabbitmqSimpleDemoApplication.class, args);}@Overridepublic void run(String... args) throws Exception {sender.sendMessage("Hello RabbitMQ Simple Mode! 👋");sender.sendMessage("Another Simple Message! 😊");}
    }
    

    运行你的 Spring Boot 应用,你将在控制台看到生产者发送的消息和消费者接收并处理的消息。🎉
    在这里插入图片描述

四、 深入理解:简单模式的幕后功臣 🕵️‍♂️

  1. 默认交换机 (Default Exchange):
    在简单模式下,我们并没有显式地声明和使用交换机。实际上,RabbitMQ 存在一个默认的匿名交换机(名称为空字符串 "")。当我们使用 rabbitTemplate.convertAndSend(queueName, message) 发送消息时,消息会被发送到这个默认交换机,并且路由键被自动设置为队列的名称。默认交换机会根据路由键(即队列名称)将消息直接投递到匹配的队列。🤫

  2. 队列的声明:确保“信箱”存在 📬
    在生产者和消费者端都进行队列声明是一个良好的实践。它可以确保在消息发送和接收之前,队列已经存在。如果队列不存在,RabbitMQ 会自动创建它。✅

  3. 消费者的确认机制 (Acknowledgement):保障消息可靠性 🛡️
    在 Spring AMQP 中,默认的确认模式是自动确认。这意味着当消息被消费者接收到后,Spring AMQP 会自动向 RabbitMQ 发送确认。然而,在生产环境中,为了保证消息的可靠性,建议配置为手动确认,并在消费者成功处理消息后显式地发送确认。这可以通过配置 listener.ack-mode 或在代码中手动发送确认来实现。👍

五、 简单模式的局限性与进阶 🤔

简单模式虽然简单易懂,但在一些复杂的场景下可能存在局限性:

  • 耦合性: 生产者需要知道确切的队列名称。 🔗
  • 灵活性不足: 无法根据消息的类型或内容进行更灵活的路由。 🗺️➡️📍

为了克服这些局限性,RabbitMQ 提供了其他更高级的工作模式,例如工作队列模式 👷‍♂️👷‍♀️、发布/订阅模式 📢📻、路由模式 🚦➡️🔍 和主题模式 📰➡️🔍 等。这些模式引入了交换机和绑定等概念,实现了更灵活和强大的消息路由功能。我们将在后续的文章中逐步探讨这些更高级的模式。🚀

六、 总结:简单而不平凡的开始 🎉

RabbitMQ 的简单模式以其直观性和易用性,成为了我们踏入消息队列世界的良好起点。它就像一只勤劳的小兔子 🐇,默默地将消息从一个地方安全地送到另一个地方。通过本文的讲解和代码示例,相信你已经对 RabbitMQ 的简单模式有了全面的理解。在掌握了这一基础之后,让我们一起期待探索 RabbitMQ 更多精彩的工作模式吧!✨

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/902919.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Lua 第7部分 输入输出

由于 Lua 语言强调可移植性和嵌入性 &#xff0c; 所以 Lua 语言本身并没有提供太多与外部交互的机制 。 在真实的 Lua 程序中&#xff0c;从图形、数据库到网络的访问等大多数 I/O 操作&#xff0c;要么由宿主程序实现&#xff0c;要么通过不包括在发行版中的外部库实现。 单就…

【开源】STM32HAL库移植Arduino OneWire库驱动DS18B20和MAX31850

项目开源链接 github主页https://github.com/snqx-lqh本项目github地址https://github.com/snqx-lqh/STM32F103C8T6HalDemo作者 VXQinghua-Li7 &#x1f4d6; 欢迎交流 如果开源的代码对你有帮助&#xff0c;希望可以帮我点个赞&#x1f44d;和收藏 项目说明 最近在做一个项目…

【合新通信】浸没式液冷光模块与冷媒兼容性测试技术报告

一、测试背景与核心挑战 行业需求驱动 随着800G/1.6T光模块功耗突破30W/端口&#xff0c;传统风冷已无法满足散热需求&#xff0c;浸没式液冷成为超算/AI数据中心的主流方案。冷媒兼容性是系统可靠性的关键指标&#xff0c;涉及材料腐蚀、光学性能、长期稳定性等维度。 核心…

Pandas中的日期时间date处理

Pandas提供了强大的日期和时间处理功能&#xff0c;这对于时间序列分析至关重要。本教程将介绍Pandas中处理日期时间的主要方法。包括&#xff1a; 日期时间数据的创建和转换日期时间属性的提取时间差计算和日期运算重采样和频率转换时区处理基于日期时间的索引操作 Pandas中…

Vue3文件上传组件实战:打造高效的Element Plus上传解决方案,可以对文件进行删除,查看,下载功能。

在现代Web开发中,文件上传功能是许多应用的核心需求之一。无论是企业管理系统、内容管理系统还是医疗信息系统,上传附件的功能都至关重要。本文将分享一个基于 Vue3 和 Element Plus 实现的文件上传组件,结合父子组件的协作,展示如何构建一个功能强大、用户体验友好的文件上…

AI 工程师崛起:科技浪潮下的新兴力量

在当今科技迅猛发展的时代&#xff0c;人工智能&#xff08;AI&#xff09;无疑是最热门的领域之一。随着基础模型的涌现和开源 / API 的普及&#xff0c;一种新兴的职业 ——AI 工程师&#xff0c;正逐渐崭露头角。他们在 AI 技术的应用和开发中扮演着关键角色&#xff0c;其崛…

人工智能与机器学习:Python从零实现逻辑回归模型

&#x1f9e0; 向所有学习者致敬&#xff01; “学习不是装满一桶水&#xff0c;而是点燃一把火。” —— 叶芝 我的博客主页&#xff1a; https://lizheng.blog.csdn.net &#x1f310; 欢迎点击加入AI人工智能社区&#xff01; &#x1f680; 让我们一起努力&#xff0c;共创…

济南国网数字化培训班学习笔记-第二组-5节-输电线路设计

输电线路设计 工程设计阶段划分 35kv及以上输变电工程勘测设计全过程 可行性研究&#xff08;包括规划、工程选站&#xff09;&#xff08;包括电力系统一次二次&#xff0c;站址选择及工程设想&#xff0c;线路工程选择及工程设想&#xff0c;节能降耗分析&#xff0c;环境…

【Linux网络】TCP服务中IOService应用与实现

&#x1f4e2;博客主页&#xff1a;https://blog.csdn.net/2301_779549673 &#x1f4e2;博客仓库&#xff1a;https://gitee.com/JohnKingW/linux_test/tree/master/lesson &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01; &…

Linux 怎么找Java程序的监听的端口

Linux 怎么找Java程序的监听的端口 1、假设你知道启动该Java应用的进程ID (PID)&#xff0c;可以通过以下命令查找其监听的端口&#xff1a; 首先找到该Java应用的PID&#xff1a; ps -ef | grep xxxx-1.0-RELEASE.jar或者&#xff0c;如果你知道启动命令的一部分&#xff0…

解读《数据资产质量评估实施规则》:企业数据资产认证落地的关键指南

随着“数据要素市场”建设加速&#xff0c;数据资产逐步成为企业核心资产之一。2024年4月&#xff0c;由中国质量认证中心&#xff08;CQC&#xff09;发布的《数据资产质量评估实施规则》&#xff08;编号&#xff1a;CQC96-831160-2024&#xff09;正式实施&#xff0c;为企业…

[吾爱出品] 【键鼠自动化工具】支持识别窗口、识图、发送文本、按键组合等

键鼠自动化工具 链接&#xff1a;https://pan.xunlei.com/s/VOOhDZkj-E0mdDZCvo3jp6s4A1?pwdfufb# 1、增加的找图点击功能&#xff08;不算增加&#xff0c;只能算缝补&#xff09;&#xff0c;各种的不完善&#xff0c;但是能运行。 2、因为受限于原程序的界面&#xff0c;…

【计算机视觉】CV实战项目 - 基于YOLOv5的人脸检测与关键点定位系统深度解析

基于YOLOv5的人脸检测与关键点定位系统深度解析 1. 技术背景与项目意义传统方案的局限性YOLOv5多任务方案的优势 2. 核心算法原理网络架构改进关键点回归分支损失函数设计 3. 实战指南&#xff1a;从环境搭建到模型应用环境配置数据准备数据格式要求数据目录结构 模型训练配置文…

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤

以下是在 IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤&#xff1a; 步骤 1&#xff1a;创建 Maven Web 项目 新建项目 File -> New -> Project → 选择 Maven → 勾选 Create from archetype → 选择 maven-archetype-webapp。输入 GroupId&#xff08;如 com.examp…

基于javaweb的SpringBoot+MyBatis通讯录管理系统设计与实现(源码+文档+部署讲解)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…

EFISH-SBC-RK3588无人机地面基准站项目

一、核心技术组件解析 1. EFISH-SBC-RK3588 性能优势&#xff1a;作为瑞芯微推出的高性能处理器&#xff0c;采用8nm 工艺&#xff0c;搭载ARM Cortex-A76/A55 八核架构&#xff0c;集成强大的 NPU&#xff08;神经网络处理单元&#xff09;和 GPU&#xff08;图形处理器&…

蓝桥杯 4. 卡片换位

卡片换位 原题目链接 题目描述 你玩过华容道的游戏吗&#xff1f; 这是一个类似的&#xff0c;但更简单的游戏。 看下面的 3 2 格子&#xff1a; --------- | A | * | * | --------- | B | | * | ---------在其中放置了 5 张牌&#xff0c;其中&#xff1a; A 表示关…

7.Excel:单元格格式

一 案例 1.案例1 2.案例2 3.案例3 二 三种基本数据类型 补充&#xff1a;在没有任何格式的情况下是这样对齐的。 1.文本 默认左对齐&#xff0c;文本不可参与计算。 2.数值 默认右对齐&#xff0c;数值计算精度是15位。 若超出15位&#xff0c;超出部分显示为0。 3.逻辑值 …

高效DCDC电源芯片在运动控制器中的应用:设计考量、性能评估与可靠性分析

摘要 随着工业自动化的深入推进&#xff0c;运动控制器作为自动化系统的核心组件&#xff0c;对电源芯片的性能提出了极高要求。高效率DCDC电源芯片凭借其卓越的电能转换效率、优异的负载响应特性和高功率密度&#xff0c;在运动控制器领域得以广泛应用。本文以国科安芯的ASP3…

Action:Update your application‘s configuration

在使用Maven项目时&#xff0c;有一个报错信息是&#xff1a;Update your applications configuration 这类问题&#xff0c;就是我们的application.yml文件 或者 application.properties文件 内容哪里写错了 最有可能就是对齐方式有问题