RabbitMQ入门指南(二):架构和管理控制台的使用

简介: RabbitMQ是一个高效、可靠的开源消息队列系统,广泛用于软件开发、数据传输、微服务等领域。本文主要介绍了RabbitMQ架构和管理控制台的使用等内容。

一、RabbitMQ架构

RabbitMQ架构图:

image.gif

在RabbitMQ的架构中,有几个关键的概念需要理解:

  • Publisher(生产者)
  • 生产者是消息的发送方,它负责将消息发送到RabbitMQ服务器。
  • 生产者可以向多个队列发送消息,也可以向特定的交换机发送消息。
  • 生产者通常使用AMQP协议与RabbitMQ服务器进行通信。
  • Consumer(消费者)
  • 消费者是消息的接收方,它从队列中获取并处理消息。
  • 消费者可以同时从多个队列接收消息,也可以使用长轮询或短轮询方式来控制消息的接收速度。
  • 消费者通常使用AMQP协议与RabbitMQ服务器进行通信。
  • Queue(队列)
  • 队列是RabbitMQ的核心组件,它负责存储消息。
  • 生产者发送的消息会先暂存到队列中,等待消费者处理。
  • 队列可以持久化存储消息,即使服务器重启,消息也不会丢失。
  • Exchange(交换机)
  • 交换机负责消息路由,它根据一定的规则将生产者的消息投递到特定的队列中。
  • RabbitMQ支持多种类型的交换机,如直接交换机、主题交换机和路由交换机等。
  • 交换机可以根据需要配置为单播或广播模式,以控制消息的投递方式。
  • Virtual Host(虚拟主机)
  • 虚拟主机是RabbitMQ中的一个重要概念,它起到数据隔离的作用。
  • 在一个RabbitMQ集群中,可以拥有多个虚拟主机,每个虚拟主机相互独立,有自己的交换机、队列等资源。
  • 通过虚拟主机隔离,可以实现不同应用或不同环境之间的数据隔离,提高系统的可扩展性和安全性。

二、RabbitMQ管理控制台的使用

1.Exchange交换机

Exchanges选项卡中,可以观察到众多预先定义的交换机存在。

image.gif

点击任意交换机,将进入交换机详情页面,可以在该页面使用控制台中的publish message 发送一条消息。

image.gif

在此处,通过控制台模拟了生产者发送的消息。由于不存在消费者,消息最终丢失,这表明交换机不具备存储消息的能力

image.gif

2.Queue队列

Queues and Streams选项卡中,可以新建一个队列 。

image.gif

新建队列:

image.gif

在创建队列时,有一些重要的参数需要配置,这些参数的选择直接影响消息处理,需根据业务需求合理配置,以下是对这些参数的详细解释:

Virtual Host
  • Virtual Host是RabbitMQ中的一个隔离环境,它类似于数据库中的schema或者命名空间。每个vhost都拥有自己的队列、交换机、绑定关系等。
  • 通过使用不同的vhost,可以实现不同应用或不同环境之间的数据隔离,提高系统的可扩展性和安全性。
  • 在创建队列时,需要指定其所在的vhost。
Type
  • Type定义了队列的种类。RabbitMQ支持多种类型的队列,如普通队列、持久化队列、排他队列等。
  • 根据实际需求选择合适的队列类型,可以影响消息的存储、传递和持久化等方面的特性。
Name
  • Name是队列的唯一标识符,用于在RabbitMQ中识别和区分不同的队列。
  • 在创建队列时,需要为其指定一个唯一的名称。在后续的操作中,可以通过名称来引用和操作该队列。
Durability
  • Durability选项决定了队列的持久性,可以根据业务需求选择适当的持久性设置,该设置将影响消息的可靠性及数据安全。
  • 当选择Durable时,队列将在服务器重启后继续存在。
  • 选择Transient时,队列在服务器重启后将被删除。
Arguments
  • Arguments是用于配置队列的额外参数集合。通过传入不同的参数值,可以进一步定义队列的行为和特性。
  • 例如,可以设置队列的最大长度、消息的最大寿命、消息的优先级等参数。这些参数可以根据实际业务需求进行定制化配置,以满足特定的性能和可靠性要求。

查看队列列表:

image.gif

3.绑定Exchange交换机和Queue队列

Exchanges选项卡中选择交换机:

image.gif

在交换机详情页,点击Bindings,在表单中填写要绑定的队列名称:

image.gif

查看绑定结果:

image.gif

4.发送消息

Exchanges选项卡中进入交换机详情页点击Publish message发送消息:

image.gif

Queues and Streams选项卡中,可以发现队列中已经有一条消息:

image.gif

进入队列详情页,点击Get messages,查看消息(如果有消费者监听了MQ的该队列,就能接收到消息):

image.gif

5.数据隔离

Admin选项卡中创建用户:

image.gif

查看创建结果(该用户没有任何Virtual Host的访问权限 ):

image.gif

退出登录,切换账号,并且点击Virtual Host管理页,创建Virtual Host:

image.gif

查看创建结果:

image.gif

image.gif

点击右上角的Virtual Host下拉菜单,切换Virtual Host:

image.gif

Queues and Streams选项卡中,查看队列,发现之前的队列无法查看(基于virtual host的隔离效果):

image.gif


总结

RabbitMQ是一个开源的消息队列软件,旨在提供可靠的消息传递和消息队列功能。本文主要介绍了RabbitMQ架构和管理控制台的使用等内容,希望对大家有所帮助。

相关实践学习
5分钟轻松打造应对流量洪峰的稳定商城交易系统
本实验通过SAE极速部署一个微服务电商商城,同时结合RocketMQ异步解耦、削峰填谷的能力,带大家体验面对流量洪峰仍旧稳定可靠的商城交易系统!
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
2月前
|
消息中间件 大数据 关系型数据库
RocketMQ实战—3.基于RocketMQ升级订单系统架构
本文主要介绍了基于MQ实现订单系统核心流程的异步化改造、基于MQ实现订单系统和第三方系统的解耦、基于MQ实现将订单数据同步给大数据团队、秒杀系统的技术难点以及秒杀商详页的架构设计和基于MQ实现秒杀系统的异步化架构。
319 64
RocketMQ实战—3.基于RocketMQ升级订单系统架构
|
18天前
|
消息中间件 存储 Kafka
一文带你从入门到实战全面掌握RocketMQ核心概念、架构部署、实践应用和高级特性
本文详细介绍了分布式消息中间件RocketMQ的核心概念、部署方式及使用方法。RocketMQ由阿里研发并开源,具有高性能、高可靠性和分布式特性,广泛应用于金融、互联网等领域。文章从环境搭建到消息类型的实战(普通消息、延迟消息、顺序消息和事务消息)进行了全面解析,并对比了三种消费者类型(PushConsumer、SimpleConsumer和PullConsumer)的特点与适用场景。最后总结了使用RocketMQ时的关键注意事项,如Topic和Tag的设计、监控告警的重要性以及性能与可靠性的平衡。通过学习本文,读者可掌握RocketMQ的使用精髓并灵活应用于实际项目中。
326 7
 一文带你从入门到实战全面掌握RocketMQ核心概念、架构部署、实践应用和高级特性
|
2月前
|
消息中间件 存储 设计模式
RocketMQ原理—5.高可用+高并发+高性能架构
本文主要从高可用架构、高并发架构、高性能架构三个方面来介绍RocketMQ的原理。
382 21
RocketMQ原理—5.高可用+高并发+高性能架构
|
8月前
|
消息中间件 存储 Java
RocketMQ(一):消息中间件缘起,一览整体架构及核心组件
【10月更文挑战第15天】本文介绍了消息中间件的基本概念和特点,重点解析了RocketMQ的整体架构和核心组件。消息中间件如RocketMQ、RabbitMQ、Kafka等,具备异步通信、持久化、削峰填谷、系统解耦等特点,适用于分布式系统。RocketMQ的架构包括NameServer、Broker、Producer、Consumer等组件,通过这些组件实现消息的生产、存储和消费。文章还提供了Spring Boot快速上手RocketMQ的示例代码,帮助读者快速入门。
|
3月前
|
消息中间件 人工智能 自然语言处理
基于 RocketMQ 事件驱动架构的 AI 应用实践
基于 RocketMQ 事件驱动架构的 AI 应用实践
115 2
|
10月前
|
消息中间件 存储 Java
RabbitMQ 在微服务架构中的高级应用
【8月更文第28天】在微服务架构中,服务之间需要通过轻量级的通信机制进行交互。其中一种流行的解决方案是使用消息队列,如 RabbitMQ,来实现异步通信和解耦。本文将探讨如何利用 RabbitMQ 作为服务间通信的核心组件,并构建高效的事件驱动架构。
391 2
|
3月前
|
存储 消息中间件 人工智能
基于 Apache RocketMQ 的 ApsaraMQ Serverless 架构升级
基于 Apache RocketMQ 的 ApsaraMQ Serverless 架构升级
|
9月前
|
消息中间件 弹性计算 运维
云消息队列RabbitMQ 版架构优化评测
云消息队列RabbitMQ 版架构优化评测
117 6
|
8月前
|
消息中间件 Java Kafka
RabbitMQ 入门
RabbitMQ 入门
136 0
|
10月前
|
消息中间件 存储 Java
分享一下rocketmq入门小知识
分享一下rocketmq入门小知识
104 0
分享一下rocketmq入门小知识