RabbitMQ消息中间件核心概念与实践指南

RabbitMQ概述

RabbitMQ是一款采用Erlang编程语言构建的开源消息代理软件,其官方网站为:RabbitMQ官方平台。本文将深入解析其核心架构原理与基础应用方法。

环境部署

部署过程中需要关注两个关键端口配置:
* 15672:管理控制台的访问入口
* 5672:消息传输处理接口
完成安装后,通过http://127.0.0.1:15672即可访问管理界面。首次登录需使用预设的管理员凭证。成功登录后将显示系统概览面板:
RabbitMQ消息中间件核心概念与实践指南
RabbitMQ的系统架构示意图如下:
RabbitMQ消息中间件核心概念与实践指南
主要包含以下核心组件:
* 消息发布者:负责产生并发送消息的应用程序
* 消息订阅者:接收并处理消息的服务端
* 消息队列:临时存储待处理消息的缓冲区
* 路由交换器:决定消息分发路径的核心组件
* 虚拟空间:实现多租户隔离的逻辑分区
这些组件均可通过管理控制台进行配置,后续章节将详细介绍控制台操作。

消息传输机制

交换器详解

在Exchanges管理界面中,系统预置了多种交换器类型:
RabbitMQ消息中间件核心概念与实践指南
通过控制台的publish message功能可以模拟消息发送:
RabbitMQ消息中间件核心概念与实践指南
RabbitMQ消息中间件核心概念与实践指南
实验证明交换器不具备消息持久化能力。

队列创建

在Queues界面新建消息队列:
RabbitMQ消息中间件核心概念与实践指南
命名为hello.queue1
RabbitMQ消息中间件核心概念与实践指南
继续创建第二个队列hello.queue2,最终结果:
RabbitMQ消息中间件核心概念与实践指南
此时向amq.fanout发送消息仍无法到达队列,说明需要建立绑定关系。

建立绑定

在Exchange详情页的Bindings菜单中配置队列绑定:
RabbitMQ消息中间件核心概念与实践指南
完成两个队列的绑定后:
RabbitMQ消息中间件核心概念与实践指南

消息验证

再次发送测试消息:
RabbitMQ消息中间件核心概念与实践指南
在队列中查看接收到的消息:
RabbitMQ消息中间件核心概念与实践指南
通过get message功能查看消息详情:
RabbitMQ消息中间件核心概念与实践指南
RabbitMQ消息中间件核心概念与实践指南
此时若有消费者监听对应队列即可处理消息。

多租户隔离

用户权限

Admin界面展示用户管理功能:
RabbitMQ消息中间件核心概念与实践指南
关键字段说明:
* 用户名:系统标识
* 权限标签:定义用户角色
* 可访问空间:指定资源范围

虚拟主机

退出当前登录:
RabbitMQ消息中间件核心概念与实践指南
创建专属虚拟主机:
RabbitMQ消息中间件核心概念与实践指南
创建完成后:
RabbitMQ消息中间件核心概念与实践指南
切换虚拟主机后,队列列表发生变化:
RabbitMQ消息中间件核心概念与实践指南

SpringAMQP集成开发

基础配置

添加Maven依赖:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

快速示例

消息生产者

配置连接参数:

spring:
rabbitmq:
host: 127.0.0.1
port: 5672
virtual-host: /hmall
username: hmall
password: 123

发送消息示例:

@SpringBootTest
public class MessageSenderTest {
@Autowired
private RabbitTemplate rabbitTemplate;
@Test
public void sendSimpleMessage() {
rabbitTemplate.convertAndSend("simple.queue", "测试消息");
}
}

消息消费者

监听处理消息:

@Component
public class MessageReceiver {
@RabbitListener(queues = "simple.queue")
public void processMessage(String content) {
System.out.println("收到消息:" + content);
}
}

工作队列模式

创建work.queue队列:
RabbitMQ消息中间件核心概念与实践指南
批量发送测试:

@Test
public void testWorkQueue() {
for(int i=0; i<50; i++){
rabbitTemplate.convertAndSend("work.queue", "消息"+i);
}
}

消息路由模式

广播模式

配置示例:

@Configuration
public class BroadcastConfig {
@Bean
public FanoutExchange fanoutExchange(){
return new FanoutExchange("broadcast.exchange");
}
}

定向路由

注解式声明:

@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = "route.queue1"),
exchange = @Exchange(name = "direct.exchange", type = ExchangeTypes.DIRECT),
key = {"red","blue"}
))
public void receiveDirectMessage(String msg){
System.out.println("定向消息:"+msg);
}

主题匹配

通配符示例:

@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = "topic.queue"),
exchange = @Exchange(name = "topic.exchange", type = ExchangeTypes.TOPIC),
key = "china.#"
))
public void receiveTopicMessage(String msg){
System.out.println("主题消息:"+msg);
}

消息序列化

配置JSON转换器:

@Bean
public MessageConverter jsonMessageConverter(){
return new Jackson2JsonMessageConverter();
}

常用扩展组件

RabbitMQ支持多种功能扩展插件:
* 运维监控插件:提供Web管理界面
* 跨节点同步插件:实现集群间消息复制
* 协议支持插件:扩展STOMP等协议支持
* 监控指标插件:集成Prometheus监控
* 延迟队列插件:支持定时消息投递
[注:原文所有图片链接均保留,二维码已移除]

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/8747.html

(0)
LomuLomu
上一篇 2025 年 5 月 11 日 上午12:30
下一篇 2025 年 5 月 11 日

相关推荐

  • Microi 吾码与 JavaScript:前端低代码平台的强大组合

    ![](https://pic.it1024doc.com/csdn/202412/5916173c18b26b7984e2009ddcc49015.png) **目录** [一、引言](#一、引言) [二、Microi 吾码概述](#二、Microi-吾码概述) [三、JavaScript 在 Microi 吾码前端开发中的应用](#三、JavaScrip…

    未分类 2024 年 12 月 28 日
    28000
  • 用 Cursor 写出第一个程序

    大家好,我是汤师爷 最近几个月,Cursor迅速走红,成为一款强大的编程助手。Cursor不仅使用简单,而且通过集成各种大模型技术,编程能力一流。 Cursor是什么? Cursor是一个类似VSCode的编辑器,集成了GPT-4、Claude 3.5等LLM模型。它本质上是在VSCode的基础上添加了AI辅助编程功能。 从界面布局到操作方式都与VSCode…

    2024 年 12 月 30 日
    27500
  • 深入解析ThreadLocal机制及其在Java多线程环境中的上下文管理实践

    目录导航第一部分:ThreadLocal核心概念解析(1)ThreadLocal工作机制剖析(2)弱引用key在GC后的状态探讨(3)内存泄漏隐患与官方解决方案(4)关键源代码解读set()方法实现原理get()方法执行流程remove()方法运作机制(5)实际应用示例第二部分:构建基于ThreadLocal的上下文控制器(1)ContextManager类…

    未分类 2025 年 5 月 13 日
    7100
  • Java Druid 面试题

    Druid连接池在项目中有哪些优势? 性能优越:Druid采用了高效的连接管理机制,可以快速地创建和回收数据库连接,减少了连接的创建和销毁带来的性能开销。 监控与统计:Druid提供了详细的监控信息,包括连接池的状态、SQL执行的统计信息等,这有助于性能调优和问题诊断。 SQL日志记录:Druid内置了SQL执行日志记录功能,可以记录所有SQL语句的执行情况…

    未分类 2025 年 1 月 10 日
    31500
  • 数据库设计原则与方法

    — title: 数据库设计原则与方法 date: 2024/12/8 updated: 2024/12/8 author: cmdragon excerpt: 数据库设计是确保数据库高效、可靠运行的关键步骤。良好的数据库设计不仅能提高数据的存取速度,还能维护数据的完整性和一致性。在本节中,我们将探讨一些基本的数据库设计原则,以及常用的数据库设计方法,帮…

    未分类 2024 年 12 月 24 日
    24000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信