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 日

相关推荐

  • IDEA 2024永久激活破解教程,附激活码和工具,实测有效

    【最新教程】IDEA 2024.1.2 永久激活破解方法,附激活码和工具,实测有效 IntelliJ IDEA 是目前 Java 开发中最受欢迎的集成开发环境之一,其强大的功能和智能提示使其在开发者中拥有极高的声誉。本文将介绍如何通过脚本和激活码免费激活 IDEA 2024.1.2 版本,确保您能够永久使用这款软件。 一、下载安装 IntelliJ IDEA…

    未分类 2024 年 7 月 8 日
    1.2K00
  • 华为OD机试E卷 –分苹果 –24年OD统一考试(Java & JS & Python & C & C++)

    文章目录 题目描述 输入描述 输出描述 用例 题目解析 JS算法源码 Java算法源码 python算法源码 c算法源码 c++算法源码 题目描述 A、B 两个人把苹果分为两堆,A 希望按照他的计算规则等分苹果,他的计算规则是按照二进制加法计算,并且不计算进位 12+5=9 (1100 + 0101 = 9),B 的计算规则是十进制加法,包括正常进位,B 希…

    未分类 2025 年 1 月 19 日
    45200
  • 【Java】:lambda 表达式

    📃个人主页:island1314 🔥个人专栏:java学习 ⛺️ 欢迎关注:👍点赞 👂🏽留言 😍收藏 💞 💞 💞 1. 背景 🚀 🔥 Lambda 表达式 是JDK8新增的特性,Lambda 表达式 可以取代大部分匿名内部类,写出更优雅的Java代码,尤其在集合的遍历和其他集合操作中,可以将函数作为一个方法的参数,也就是函数作为参数传递到方法中,极大地优化代…

    2024 年 12 月 30 日
    42400
  • volatile关键字

    在Java中,使用volatile关键字修饰一个变量可以带来以下效果: 可见性 :volatile保证了变量的可见性,即当一个线程修改了volatile变量的值时,新值对于其他线程来说是立即可见的。这意味着,如果一个线程更新了volatile变量,其他线程在访问这个变量时,总是能看到最新的值。 禁止指令重排 :volatile变量的写操作对于后续的读操作是先…

    未分类 2025 年 1 月 6 日
    36700
  • python SQLAlchemy ORM——从零开始学习 01 安装库

    01基础库 1-1安装 依赖库:sqlalchemy “`python pip install sqlalchemy #直接安装即可 “` 1-2导入使用 这里讲解思路【个人的理解】,具体写其实就是这个框架: 导入必要的接口【有创建engine以及declarative_base】 通过create_engine接口创建engine,根据翻译可以翻译成引…

    2025 年 1 月 11 日
    54500

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信