RabbitMQ基础篇之数据隔离

文章目录

需求

  1. 创建用户:为每个项目或业务创建不同的用户。
  2. 创建虚拟主机:为每个用户创建不同的虚拟主机。
  3. 测试数据隔离:通过不同用户登录,测试虚拟主机之间的数据隔离。
  4. 作用:
  • 数据隔离:不同虚拟主机中的数据相互独立,彼此隔离。
  • 每个虚拟主机内部可以有队列和交换机,且它们之间不会互相干扰。

操作步骤

创建用户
  • 进入 RabbitMQ 控制台,点击 Admin,选择 Users
  • 点击 Add a user,填写用户信息:
    • Username :如 nhuan(可以根据项目命名)。
    • Password :如 123
    • Tag :建议选择 admin 角色,赋予用户最高权限(可以管理所有资源)。
  • 创建完成后,新的用户会显示在用户列表中,但是没有虚拟主机访问权限。
  • 注意:用户创建后,默认没有访问虚拟主机的权限。
为用户创建虚拟主机
  • 登录新创建的用户,并尝试操作虚拟主机:
    • 该用户只能操作与自己关联的虚拟主机中的队列和交换机。
    • 数据隔离效果:如果用户尝试操作其他虚拟主机中的队列,将会遇到权限错误(即无法操作其他虚拟主机中的数据)。
  • 进入 RabbitMQ 控制台,点击 Virtual Hosts
  • 点击 Add a virtual host,为用户创建新的虚拟主机:
    • Name :如 nhuan
    • Description(可选):可以描述虚拟主机的用途。
  • 新创建的虚拟主机会自动分配给当前登录用户。
测试数据隔离
  • 登录新创建的用户,并尝试操作虚拟主机:
    • 该用户只能操作与自己关联的虚拟主机中的队列和交换机。
    • 数据隔离效果:如果用户尝试操作其他虚拟主机中的队列,将会遇到权限错误(即无法操作其他虚拟主机中的数据)。
  • 通过右上角选择不同虚拟主机,可以切换视图,只展示该虚拟主机中的数据。
  • 创建和操作队列 :用户可以在自己虚拟主机内创建队列并进行消息操作。
    • 队列如 simple.queue 可以创建并操作,发送和接收消息不受其他虚拟主机的影响。

总结

  • 通过为不同项目或业务创建独立的用户和虚拟主机,实现了 数据隔离
  • 不同的虚拟主机之间的数据不会互相影响,保证了各业务的数据安全性和独立性。

实际操作

  1. 创建用户 :用户命名如 nhuan,密码设置为 123,并赋予管理员权限。
  2. 创建虚拟主机 :为 nhuan 用户创建名为 nhuan 的虚拟主机。
  3. 验证数据隔离 :通过登录不同用户,确保虚拟主机之间的数据隔离效果。

关键点回顾:

  • 虚拟主机:实现 RabbitMQ 数据隔离的核心,确保不同业务之间没有干扰。
  • 用户与虚拟主机的关系:每个用户可以访问多个虚拟主机,但通常每个虚拟主机与特定用户关联。
  • 权限控制:用户通过角色和虚拟主机权限控制,确保数据隔离的安全性。
相关推荐
用户8307196840823 小时前
RabbitMQ vs RocketMQ 事务大对决:一个在“裸奔”,一个在“开挂”?
后端·rabbitmq·rocketmq
初次攀爬者1 天前
RabbitMQ的消息模式和高级特性
后端·消息队列·rabbitmq
初次攀爬者3 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
让我上个超影吧4 天前
消息队列——RabbitMQ(高级)
java·rabbitmq
塔中妖4 天前
Windows 安装 RabbitMQ 详细教程(含 Erlang 环境配置)
windows·rabbitmq·erlang
断手当码农4 天前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
初次攀爬者4 天前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端
业精于勤_荒于稀4 天前
物流订单系统99.99%可用性全链路容灾体系落地操作手册
分布式
Ronin3054 天前
信道管理模块和异步线程模块
开发语言·c++·rabbitmq·异步线程·信道管理
Asher05094 天前
Hadoop核心技术与实战指南
大数据·hadoop·分布式