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

news2024/11/25 11:51:19

专栏导航

RabbitMQ入门指南

从零开始了解大数据


目录

专栏导航

前言

一、RabbitMQ架构

二、RabbitMQ管理控制台的使用

1.Exchange交换机

2.Queue队列

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

4.发送消息

5.数据隔离

总结


前言

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


一、RabbitMQ架构

RabbitMQ架构图:

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

  • Publisher(生产者)

    • 生产者是消息的发送方,它负责将消息发送到RabbitMQ服务器。
    • 生产者可以向多个队列发送消息,也可以向特定的交换机发送消息。
    • 生产者通常使用AMQP协议与RabbitMQ服务器进行通信。
  • Consumer(消费者)

    • 消费者是消息的接收方,它从队列中获取并处理消息。
    • 消费者可以同时从多个队列接收消息,也可以使用长轮询或短轮询方式来控制消息的接收速度。
    • 消费者通常使用AMQP协议与RabbitMQ服务器进行通信。
  • Queue(队列)

    • 队列是RabbitMQ的核心组件,它负责存储消息。
    • 生产者发送的消息会先暂存到队列中,等待消费者处理。
    • 队列可以持久化存储消息,即使服务器重启,消息也不会丢失。
  • Exchange(交换机)

    • 交换机负责消息路由,它根据一定的规则将生产者的消息投递到特定的队列中。
    • RabbitMQ支持多种类型的交换机,如直接交换机、主题交换机和路由交换机等。
    • 交换机可以根据需要配置为单播或广播模式,以控制消息的投递方式。
  • Virtual Host(虚拟主机)

    • 虚拟主机是RabbitMQ中的一个重要概念,它起到数据隔离的作用。
    • 在一个RabbitMQ集群中,可以拥有多个虚拟主机,每个虚拟主机相互独立,有自己的交换机、队列等资源。
    • 通过虚拟主机隔离,可以实现不同应用或不同环境之间的数据隔离,提高系统的可扩展性和安全性。

二、RabbitMQ管理控制台的使用

1.Exchange交换机

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

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

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

2.Queue队列

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

新建队列:

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

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

查看队列列表:

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

Exchanges选项卡中选择交换机:

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

查看绑定结果:

4.发送消息

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

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

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

5.数据隔离

Admin选项卡中创建用户:

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

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

查看创建结果:

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

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


总结

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

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

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

相关文章

HTML_CSS的基本选择器的使用及其作用范围和优先级

目录 ✨CSS的使用:行内样式内部样式外部样式 ✨CSS基本选择器:id选择器class选择器标签选择器 ✨优先级:选择器的优先级样式表的优先级 ✨CSS的使用: 根据定义CSS的位置不同,分为行内样式、内部样式和外部样式 行内样…

java配置+J_IDEA配置+git配置+maven配置+基本语句

当前目录文件夹dir 进入文件夹cd 返回上一级cd.. 创建文件夹:mkdir 文件名删除文件夹:rd 文件夹名, 目录不为空不能直接删 rd /s 带子文件夹一起删 清屏cls 切换d盘才能进入 下载git地址: Git - Downloading Package (g…

隐私计算介绍

这里只对隐私计算做一些概念性的浅显介绍,作为入门了解即可 目录 隐私计算概述隐私计算概念隐私计算背景国外各个国家和地区纷纷出台了围绕数据使用和保护的公共政策国内近年来也出台了数据安全、隐私和使用相关的政策法规 隐私计算技术发展 隐私计算技术安全多方计…

JDBC 数据库连接池

目录 一、什么是数据库连接池二、为什么需要数据库连接池?三、JDBC 数据库连接池的实现四、C3P0的使用1、加入c3p0 jar包2、配置xml文件3、c3p0-config.xml模板4、C3P0的使用 五、Druid的使用1、加入Druid jar包2、定义配置文件:3、Druid连接池的使用 六、HikariCP的…

【最新】2023年30米分辨率土地利用遥感监测数据

改革开放以来,中国经济的快速发展对土地利用模式产生了深刻的影响。同时,中国又具有复杂的自然环境背景和广阔的陆地面积,其土地利用变化不仅对国家发展,也对全球环境变化产生了深刻的影响。为了恢复和重建我国土地利用变化的现代…

硬件基础-二极管

3.二极管 正偏时是多数载流子载流导电,反偏时是少数载流子载流导电。所以,正偏电流大,反偏电流小,PN 结显示出单向电性。多数载流子正向通过 PN 结时就需要克服内电场的作用,需要约 0.7 伏的外加电压,这是…

windows10录屏快捷键,让你效率翻倍!

“大家知道,windows 10系统有录屏快捷键吗?每次都要通过搜索才能打开,感觉花费的时间太多了,要是可以快速打开就方便多了,所以有人知道windows10系统的录屏快捷键是什么吗?” 在windows 10系统中&#xff…

OpenCV-8RGB和BGR颜色空间

一. RGB和BGR 最常见的色彩空间就是RGB,人眼也是基于RGB的色彩空间去分辨颜色。 OpenCV默认使用的是BGR. BGR和RGB色彩空间的区别在于图片在色彩通道上的排列顺序不同。 二.HSV, HSL和YUV 1.HSV(HSB) OpenCV用的最多的色彩空间是HSV. Hue:色相&…

【玩转 TableAgent 数据智能分析】股票交易数据分析+预测

文章目录 一、什么是TableAgent二、TableAgent 的特点三、实践前言四、实践准备4.1 打开官网4.2 注册账号4.3 界面介绍4.4 数据准备 五、确认分析需求六、TableAgent体验七、分析结果解读八、总结&展望 一、什么是TableAgent TableAgent是一款面向企业用户的智能数据分析工…

Pytorch深度强化学习案例:基于Q-Learning的机器人走迷宫

目录 0 专栏介绍1 Q-Learning算法原理2 强化学习基本框架3 机器人走迷宫算法3.1 迷宫环境3.2 状态、动作和奖励3.3 Q-Learning算法实现3.4 完成训练 4 算法分析4.1 Q-Table4.2 奖励曲线 0 专栏介绍 本专栏重点介绍强化学习技术的数学原理,并且采用Pytorch框架对常见…

AntDB-T提升查询性能的关键之查询优化解析

查询优化器是提升查询效率非常重要的手段,本文将主要介绍AntDB-T数据库查询优化的相关设计。AntDB-T数据库是一款企业级通用分布式关系型数据库,而查询是AntDB-T数据库管理系统中最关键、最吸引人的功能之一。每个生产数据库系统每天都需要处理大量的查询…

python【matplotlib】鼠标拖动滚动缩放坐标范围和拖动图例共存

背景 根据前面的博文: python【matplotlib】画图鼠标缩放拖动动态改变坐标轴范围 和Python【Matplotlib】图例可拖动改变位置 两个博文,博主考虑了一下,如何将两者的功能结合起来,让二者共存。 只需根据Python【Matplotlib】鼠标…

【音视频 | AAC】AAC音频编码详解

😁博客主页😁:🚀https://blog.csdn.net/wkd_007🚀 🤑博客内容🤑:🍭嵌入式开发、Linux、C语言、C、数据结构、音视频🍭 🤣本文内容🤣&a…

【GD32307E-START】06 ST7735 SPI-LCD显示模块移植

软硬件平台 GD32F307E-START Board开发板GCC Makefile1.8寸TFTLCD 分辨率128*160 驱动IC ST7735S 接口定义 序号引脚标号说明1GND接地2VCC5V/3.3V电源输入3SCKSPI总线时钟信号4SDASPI总线写数据信号5RESET液晶屏复位信号,低电平复位6DC液晶屏寄存器/数据选择信…

LinuxCNC系统安装

首先我们需要准备一个U盘来安装系统,然后进入Debian官网。操作系统处,点击“下载Debian”。 如果需要下载其他比较全版本,可以点击“其他下载链接”,选择DVD的安装,因为是国外的网站,最好不要选择网络安装。…

【每日OJ—有效的括号(栈)】

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 1、有效的括号题目: 1.1方法讲解: 1.2代码实现: 总结 前言 世上有两种耀眼的光芒,一种是正在升起的太阳&#…

机器学习:增强式学习Reinforcement learning

收集有标签数据比较困难的时候同时也不知道什么答案是比较好的时候可以考虑使用强化学习通过互动,机器可以自己知道什么结果是好的,什么结果是坏的 Outline 什么是RL Action就是一个functionEnvironment就是告诉这个Action是好的还是坏的 例子 Space i…

2023年度IT168技术卓越奖名单:亚信安慧AntDB数据库

信创卓越贡献奖:湖南亚信安慧科技有限公司 一句话点评:亚信安慧的核心交易数据库AntDB具有应用时间久(15年)、运行节点多(2000)、数据规模大(PB级)、产品稳定可靠(500项目…

L1-050:倒数第N个字符串

题目描述 给定一个完全由小写英文字母组成的字符串等差递增序列,该序列中的每个字符串的长度固定为 L,从 L 个 a 开始,以 1 为步长递增。例如当 L 为 3 时,序列为 { aaa, aab, aac, ..., aaz, aba, abb, ..., abz, ..., zzz }。这…

Spring Cloud + Vue前后端分离-第6章 通用代码生成器开发

Spring Cloud Vue前后端分离-第6章 通用代码生成器开发 6-1 代码生成器原理介绍 1.增加generator模块,用于代码生成 2.集成freemarker 通用代码生成器开发 FreeMarker 是一款模版引擎,通过模板生成文件,包括html页面,excel …