捋明白 RabbitMQ 中的权限系统,再也不担心消息发送失败了!

开发 前端
不管我们是通过网页还是通过命令行工具创建用户对象,刚创建好的用户对象都是没法直接使用的,需要我们首先把这个用户置于某一个 vhost 之下,然后再赋予其权限,有了权限,这个用户才可以正常使用。

 [[438846]]

不管我们是通过网页还是通过命令行工具创建用户对象,刚创建好的用户对象都是没法直接使用的,需要我们首先把这个用户置于某一个 vhost 之下,然后再赋予其权限,有了权限,这个用户才可以正常使用。

那么今天我们就来了解一下 RabbitMQ 中的权限系统,看下这个权限系统是什么样子的。

1. RabbitMQ 权限系统介绍

RabbitMQ 是从 1.6 这个版本开始实现了一套 ACL 风格的权限系统,可能有小伙伴还不知道什么是 ACL 风格的权限系统,可以看看松哥之前发的这两篇文章:

Spring Security 中如何细化权限粒度?

一个案例演示 Spring Security 中粒度超细的权限控制!

在这套 ACL 风格的权限管理系统中,允许非常多细粒度的权限控制,可以为不同用户分别设置读、写以及配置等权限。

这里涉及到三种不同的权限:

  • 读:和消息消费有关的所有操作,包括清除整个队列的消息。
  • 写:发布消息。
  • 配置:消息队列、交换机等的创建和删除。

这是 RabbitMQ 权限系统的一个简单介绍。

2. 操作和权限的对应关系

接下来,下图展示了操作和权限的对应关系:

公众号后台回复 rabbitmq_permission 可以获取这张图的 Excel 表格。

执行什么命令,需要什么权限,这张图描述的一清二楚了。

3. 权限操作命令

RabbitMQ 中权限操作命令格式如下:

  1. rabbitmqctl set_permissions [-p vhosts] {user} {conf} {write} {read

这里有几个参数:

  • [-p vhost]:授予用户访问权限的 vhost 名称,如果不写默认为 /。
  • user:用户名。
  • conf:用户在哪些资源上拥有可配置权限(支持正则表达式)。
  • write:用户在哪些资源上拥有写权限(支持正则表达式)。
  • read:用户在哪些资源上拥有读权限(支持正则表达式)。

至于可配置权限能干嘛,写权限能干嘛,读权限能干嘛,大家可以参考第二小节,这里不再赘述。

松哥来举一个简单的例子。

假设我们有一个名为 zhangsan 的用户,我们希望该用户在 myvh 虚拟主机下具备所有权限,那么我们的操作命令如下:

  1. rabbitmqctl set_permissions -p myvh zhangsan ".*" ".*" ".*" 

执行结果如下:

接下来执行如下命令可以验证授权是否成功:

  1. rabbitmqctl -p myvh list_permissions 

可以看到,张三的权限已经赋值到位。

在上面的授权命令中,我们用的都是 ".*",松哥再额外说下这个通配符:

".*":这个表示匹配所有的交换机和队列。

"javaboy-.*":这个表示匹配名字以 javaboy- 开头的交换机和队列。

"":这个表示不匹配任何队列与交换机(如果想撤销用户的权限可以使用这个)。

我们可以使用如下命令来移除某一个用户在某一个 vhost 上的权限,例如移除 zhangsan 在 myvh 上的所有权限,如下:

  1. rabbitmqctl clear_permissions -p myvh zhangsan 

执行完成后,我们可以通过 rabbitmqctl -p myvh list_permissions 命令来查看执行结果是否生效,最终执行效果如下:

如果一个用户在多个 vhost 上都有对应的权限,按照上面的 rabbitmqctl -p myvh list_permissions 命令只能查看一个 vhost 上的权限,此时我们可以通过如下命令来查看 lisi 在所有 vhost 上的权限:

  1. rabbitmqctl list_user_permissions lisi 

4. Web 管理页面操作

当然,如果你不想敲命令,也可以通过 Web 管理端去操作权限。

在 Admin 选项卡,点击用户名称,就可以给用户设置权限了,如下:

可以设置权限,也可以清除权限。

当然,在网页上还有一个 Topic Permissions,这是 RabbitMQ3.7 开始的一个新功能,可以针对某一个 topic exchange 设置权限,主要针对 STOMP 或者 MQTT 协议,我们日常 Java 开发用上这个配置的机会很少。如果用户不设置的话,相应的 topic exchange 也总是有权限的。

5. 小结

好啦,这就是关于 RabbitMQ 权限管理的一点点小知识~感兴趣的小伙伴可以去试试啦~

本文转载自微信公众号「江南一点雨」,可以通过以下二维码关注。转载本文请联系江南一点雨公众号。

 

责任编辑:武晓燕 来源: 江南一点雨
相关推荐

2015-05-29 09:01:48

2021-12-21 09:05:46

命令Linux敲错

2023-06-06 08:11:09

kafka事务消息语义

2020-04-30 09:19:56

Docker容器虚拟机

2020-01-21 21:15:16

WiFi网络WiFi6

2020-06-15 08:03:17

大文件OOM内存

2023-07-14 21:34:40

JVM上下线线程

2021-08-13 22:38:36

大数据互联网技术

2019-09-04 10:00:07

手机人脸识别

2022-09-14 08:02:25

加密算法Bcryp

2015-10-22 10:38:43

Wi-Fi燃气报警器

2021-06-04 12:05:03

Redis Bitmap 数据库

2021-06-11 07:14:04

QQ音乐微信翻译

2018-10-30 16:10:41

Linux救援模式命令

2021-06-08 07:48:26

数据 Python开发

2016-08-09 16:17:37

高德地图TFBOYS大数据

2021-09-30 22:46:05

微信安全支付

2020-04-30 09:01:27

路由器安全网络安全路由器

2020-04-10 09:55:28

Git 工具黑魔法
点赞
收藏

51CTO技术栈公众号