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 日

相关推荐

  • “探索Java List的无限可能:从基础到高级应用“

    Java List 探索之旅 1. List 简介 2. List 接口概览 3. List 实际应用 一:List 的定义在Java的集合框架中,List是一个接口,继承自Collection。它代表了一个有序的元素集合,允许对元素进行增加、删除、修改和查询等操作。 Collection接口定义了一系列集合操作的方法,而Iterable接口则允许我们对集合…

    2024 年 12 月 28 日
    39500
  • Java开发环境搭建全指南:从下载安装到配置验证

    目录 第一步:获取与安装JDK 第二步:设置系统环境 第三步:检查配置结果 第一步:获取与安装JDK 1、官方下载入口访问Oracle官网Java下载页面:https://www.oracle.com/java/technologies/downloads/2、根据需求选择适合的版本,并匹配操作系统类型3、下载完成后,运行安装程序并按照向导操作4、建议修改默…

    2025 年 5 月 19 日
    70300
  • 用 Cursor 写出第一个程序

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

    2025 年 1 月 6 日
    57700
  • 架构师启示录:知识模型、落地方法与思维模式PDF、EPUB免费下载

    适读人群 :资深程序员、初级架构师 从架构知识模型、架构落地方法、架构思维模式三大维度介绍架构师的能力模型,带你穿越“认知迷雾” 电子版仅供预览,下载后24小时内务必删除,支持正版,喜欢的请购买正版书籍 点击原文去下载 书籍信息 作者: 灵犀出版社: 机械工业出版社出版年: 2024-3页数: 212装帧: 平装丛书: 架构师书库ISBN: 97871117…

    2025 年 1 月 6 日
    52900
  • Microi 吾码与 JavaScript:前端低代码平台的强大组合

    目录 一、引言 二、Microi 吾码概述 三、JavaScript 在 Microi 吾码前端开发中的应用 (一)前端 V8 引擎与 JavaScript (二)接口引擎与 JavaScript 四、JavaScript 在 Microi 吾码后端开发中的协同 (一)与 C# 后端框架的交互 (二)利用 gRPC 实现跨语言通信 五、Microi 吾码中 …

    2025 年 1 月 1 日
    55200

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信