RabbitMQ:数据隔离

目录

  • 一、概述
    • [1.1 虚拟主机(vHost)](#1.1 虚拟主机(vHost))
    • [1.2 应用场景](#1.2 应用场景)
  • 二、实现方式
    • [2.1 图像化界面](#2.1 图像化界面)
    • [2.2 命令行创建](#2.2 命令行创建)

一、概述

RabbitMQ 通过 虚拟主机(Virtual Host,简称 vHost) 实现数据隔离,其核心机制与实现方式如下:

1.1 虚拟主机(vHost)

独立命名空间:每个vHost有独立的交换机(Exchange)、队列(Queue)、绑定关系(Binding)等资源,命名互不冲突。例如:vhost_A 中的队列 queue1 与 vhost_B 中的队列 queue1 是两个完全独立的对象。

权限隔离:用户需被授权访问特定 vHost 才能操作其中的资源。默认情况下,新创建的用户无任何 vHost 访问权限,需通过管理界面或 API 显式授权。

物理隔离(逻辑隔离):同一 RabbitMQ 服务器上的不同 vHost 共享物理资源(如磁盘、内存),但逻辑上完全隔离。类似 Docker 容器或虚拟机,资源独立但运行在同一宿主机上。

1.2 应用场景

多项目隔离:为不同项目分配独立 vHost,避免交换机/队列命名冲突。例如:项目 A 使用 /project_a,项目 B 使用 /project_b。

多环境隔离:为开发、测试、生产环境分配不同 vHost,确保数据互不干扰。例如:开发环境 /dev,测试环境 /test,生产环境 /prod。

注意: RabbitMQ 不支持直接跨 vHost 路由消息,需通过外部服务中转

二、实现方式

2.1 图像化界面

首先需要创建一个用户,例如mamf

创建完用户之后需要创建一个vHost虚拟主机

虚拟主机创建完成之后,可以点击虚拟主机的名称分配用户,用于配置哪些用户可以使用这个虚拟主机

2.2 命令行创建

创建用户

linux 复制代码
rabbitmqctl add_user 用户名 密码

创建vHost虚拟主机

linux 复制代码
rabbitmqctl add_vhost /虚拟主机名

给用户分配权限

linux 复制代码
rabbitmqctl set_permissions -p /虚拟主机名 用户名 "." "." ".*"

给用户设置标签

linux 复制代码
rabbitmqctl set_user_tags 用户名 administrator
相关推荐
在未来等你3 小时前
Elasticsearch面试精讲 Day 13:索引生命周期管理ILM
大数据·分布式·elasticsearch·搜索引擎·面试
roman_日积跬步-终至千里8 小时前
【系统架构设计(24)】大型网站系统架构演化:从单体到分布式的技术进阶之路
分布式·系统架构
Luminbox紫创测控9 小时前
稳态太阳光模拟器 | 多源分布式设计的要点有哪些?
分布式
WHFENGHE17 小时前
输电线路分布式故障监测装置技术解析
分布式
a5876919 小时前
消息队列(MQ)高级特性深度剖析:详解RabbitMQ与Kafka
java·分布式·面试·kafka·rabbitmq·linq
hmb↑19 小时前
Kafka 3.9.x 安装、鉴权、配置详解
分布式·kafka·linq
AAA修煤气灶刘哥20 小时前
缓存世界的三座大山:穿透、击穿、雪崩,今天就把它们铲平!
redis·分布式·后端
失散1321 小时前
分布式专题——4 大厂生产级Redis高并发分布式锁实战
java·redis·分布式·缓存·架构
eqwaak01 天前
科技信息差(9.10)
网络·人工智能·分布式·ar·智能硬件
一个帅气昵称啊1 天前
C#,RabbitMQ从入门到精通,.NET8.0(路由/分布式/主题/消费重复问题 /延迟队列和死信队列/消息持久化 )/RabbitMQ集群模式
分布式·微服务·架构·rabbitmq·.net