RabbitMQ

引言

RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统。他遵循Mozilla Public License开源协议。

MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法。应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此来通信,直接调用通常是用于诸如远程过程调用的技术。排队指的是应用程序通过队列来通信。队列的使用除去了接收和发送应用程序同时执行的要求。RabbitMQ可以,多个程序同时使用RabbitMQ ,但是必须队列名称不一样。采用erlang语言,属于爱立信公司开发的。

起停服务

# 启用web管理界面
# rabbitmq-plugins enable rabbitmq_management
# 开启服务:rabbitmq-server -detached
# 关闭服务:rabbitmqctl stop (连同节点上的其它应用程序一同关闭了)
# or
# 关闭服务:rabbitmqctl stop_app (只关闭rabbitmq节点)
# 开启插件:rabbitmq-plugins enable 插件名
# 关闭插件:rabbitmq-plugins disable 插件名
# 检查rabbitmq状态:rabbitmqctl status

启动后查看进程(已开启web插件)

此时,即可打开浏览器输入http://127.0.0.1:15672地址,进入web端(如下图)

登陆用户,系统默认用户:账号:guest  密码:guest   角色:administration

如想新建用户,可通过下方命令,自行创建!

默认端口

4369 (epmd), 25672 (Erlang distribution)
5672, 5671 (AMQP 0-9-1 without and with TLS)
15672 (if management plugin is enabled)
61613, 61614 (if STOMP is enabled)
1883, 8883 (if MQTT is enabled) # 特殊说明
web:15672
api_port:5672

配置文件和日志

# 默认情况下rabbitmq的日志在     /var/log/rabbitmq/rabbit@[hostname].log
# 默认配置文件         /etc/rabbitmq/rabbitmq.config

用户管理

# 新建用户:rabbitmqctl add_user username password
# 删除用户:rabbitmqctl delete_user username
# 查看用户列表:rabbitmqctl list_users
# 查看用户列表:rabbitmqctl list_users

例:

# 新建用户 zhaok
rabbitmqctl add_user zhaok ******
# 修改用户密码 zhaok
rabbitmqctl change_password zhaok newpassword
# 删除用户 zhaok
rabbitmqctl delete_user zhaok

角色授权

角色大致有五类:
  超级管理员administrator, 监控者monitoring, 策略制定者policymaker, 普通管理者management以及其他
角色说明:
超级管理员(administrator):可登陆管理控制台(启用management plugin的情况下),可查看所有的信息,并且可以对用户,策略(policy)进行操作。


监控者(monitoring):可登陆管理控制台(启用management plugin的情况下),同时可以查看rabbitmq节点的相关信息(进程数,内存使用情况,磁盘使用情况等)

策略制定者(policymaker):可登陆管理控制台(启用management plugin的情况下), 同时可以对policy进行管理。但无法查看节点的相关信息(上图红框标识的部分)


普通管理者(management):仅可登陆管理控制台(启用management plugin的情况下),无法看到节点信息,也无法对策略进行管理。


其他(other):无法登陆管理控制台,通常就是普通的生产者和消费者。

略。。。

授权角色

# 授权角色:rabbitmqctl  set_user_tags  User  Tag
# 查看用户角色: 可通过rabbitmqctl list_users查看
# 重新授权,直接重新执行授权命令即可

User为用户名, Tag为角色名(对应于上面的administrator,monitoring,policymaker,management,或其他自定义名称)

例:

# 授权单角色
rabbitmqctl set_user_tags zhaok monitoring
# 授权多角色
rabbitmqctl set_user_tags zhaok monitoring policymaker

可通过查看用户命令来查看用户角色

权限授权

用户授权说明(与角色之间不同,不可混淆)

rabbitmq的权限控制通过两层来实现,一是vhost的权限,二是确认有权限访问vhost后,对vhost内资源的权限控制(配置,读,写)

通俗的可以理解为:指用户对exchange,queue的操作权限,包括配置权限,读写权限。配置权限会影响到exchange,queue的声明和删除。读写权限影响到从queue里取消息,向exchange发送消息以及queue和exchange的绑定(bind)操作等等

授权分三个操作:
  读:有关消费消息的任何操作,包括"清除"整个队列
  写:发布消息
  配置:队列和交换机的创建和删除

每一条访问控制是由以下四部分组成:
  1、被授予访问权限的用户
  2、权限控制应用的Vhost
  3、需要授权的读/写/配置权限组合
  4、权限范围——权限控制仅应用与客户端命名的队列和交换机
注:访问控制权限是无法跨越Vhost的!!!

(1) 设置用户权限
rabbitmqctl set_permissions -p VHostPath User ConfP WriteP ReadP
(2) 查看(指定hostpath)所有用户的权限信息
rabbitmqctl list_permissions [-p VHostPath]
(3) 查看指定用户的权限信息
rabbitmqctl list_user_permissions User
(4) 清除用户的权限信息
rabbitmqctl clear_permissions [-p VHostPath] User

例:

# 单用户授权
示例:rabbitmqctl set_permissions -p broker_one producer_one ".*" ".*" ".*"
# 说明:给用户producer_one授权 vhost名称为broker_one的 配置 写入 读取的权限
示例:rabbitmqctl set_permissions -p broker_one producer_one " " ".*" " "
# 说明:给用户producer_one授权 vhost名称为broker_one的 配置 写入 读取的权限

特殊说明:
  “---” 双引号中的信息为正则表达式
  ".*" 表示配置任何队列和交换机
  "checks-.*"表示只能配置名字以"checks-"开头的队列和交换机
  " " 不匹配队列和交换机

virtual_host管理

新建virtual_host: rabbitmqctl add_vhost xxx
撤销virtual_host: rabbitmqctl delete_vhost xxx
查看列表:rabbitmqctl list_vhosts

队列管理

查看当前队列信息:rabbitmqctl list_queues
清除所有队列:rabbitmqctl reset

获取服务器状态信息

查看节点信息:rabbitmqctl cluster_status
服务器状态:rabbitmqctl status
queue信息:rabbitmqctl list_queues # 默认会查看 / 下的队列
# 如果想看其他vhost中的,加参数 -p "vhost_name"
exchange信息:rabbitmqctl list_exchanges
binding信息:rabbitmqctl list_bindings
connection信息:rabbitmqctl list_connections
channel信息:rabbitmqctl list_channels

集群命令

集群的事宜会有详解,暂略

查看集群状态:rabbitmqctl cluster_status
创建集群:rabbitmqctl join_cluster 节点@主机名

全命令

RabbitMQ权限的更多相关文章

  1. RabbitMQ权限控制原理

    我们在使用MQ搭建系统的时候,经常要开放队列给外接系统访问.外接系统的稳定性是不可控的.为了防止外接系统不稳定导致误操作破坏了MQ的配置或数据,需要对MQ做比较精细的权限控制. 我的需求是这样的: 我 ...

  2. rabbitMQ权限相关命令

    权限相关命令为: (1) 设置用户权限 rabbitmqctl  set_permissions  -p  VHostPath  User  ConfP  WriteP  ReadP (2) 查看(指 ...

  3. RabbitMQ 权限分离&HA操作文档

    概要 默认情况下,使用帐号guest帐号登陆MQ,所有用户的queue信息,全部创建在根目录/的virtual host下,而这样,就会导致,任一用户登录后,都能看到其他用户的queue信息. 针对以 ...

  4. rabbitmq权限细分二

    禁止用户远程登录 主要有以下几步 1.进入容器 docker exec -it ID /bin/bash 2.打开配置文件 vi /etc/rabbitmq/rabbitmq.conf 3.加入配置, ...

  5. RabbitMQ用户角色及权限控制

    RabbitMQ的用户角色分类:none.management.policymaker.monitoring.administrator RabbitMQ各类角色描述:none不能访问 managem ...

  6. RabbitMQ用户角色及权限控制(转)

    转载至:https://blog.csdn.net/awhip9/article/details/72123257 2017年05月15日 10:39:26 awhip9 阅读数:3538   ### ...

  7. RabbitMQ用户角色及权限控制 -2

    1.RabbitMQ的用户角色分类: none.management.policymaker.monitoring.administrator none 不能访问 management plugin ...

  8. RabbitMQ用户角色及权限控制(不错)

    ########################用户角色####################### RabbitMQ的用户角色分类:none.management.policymaker.moni ...

  9. rabbitMQ安装docker版 /权限管理命令

    1.进入docker hub镜像仓库地址:https://hub.docker.com/ 2.搜素rabbitMQ 查询镜像,可以看到多种类型,选择带有web页面的(managment) 3.拉取镜像 ...

随机推荐

  1. HNOI2004宠物收养所(splay维护二叉搜索树模板题)

    描述 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的宠物,阿Q根据领养者的要求通过他自己发明的一个特殊的公式,得出该领 ...

  2. 洛谷3384&bzoj1036树链剖分

    值得注意的是: 一个点的子树是存在一起的...也就是说我们修改子树的时候只用... /********************************************************* ...

  3. Link-cut-tree 学习记录 & hdu4010

    网上的lct一抓一大把,所以我也不再写什么讲解了,只写一写自己的看法. Link-cut-tree 是用于维护动态树的一种数据结构 所谓动态树就是一片存在边的添加与删除的森林中的一棵树 所以我们要快速 ...

  4. 立方体贴图(Cubemap)

    http://blog.csdn.net/asdjy123/article/details/51190643 点击打开链接 好东西保存方便查看 立方体贴图(Cubemap) 原文 Cubemaps 作 ...

  5. bzoj 3994 约数个数和 —— 反演+数论分块

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3994 推导过程和这里一样:https://www.cnblogs.com/MashiroSk ...

  6. debian服务查询

    1.查询 用root身份执行service --status-all查看所有服务的状态 "+" started "-" stopped "?" ...

  7. 如何调整chm文字字体大小

    chm文档是使用用层叠样式表来控制字符大小的,通过IE的改变“文字大小”是没效果的,那我们是不是就没有办法改变它的大小了呢?显然不是的. 工具/原料   chm文件 方法/步骤     首先打开chm ...

  8. java对象在内存中的结构(HotSpot虚拟机)

    一.对象的内存布局 HotSpot虚拟机中,对象在内存中存储的布局可以分为三块区域:对象头(Header).实例数据(Instance Data)和对齐填充(Padding). 从上面的这张图里面可以 ...

  9. mysql基础之三:char与varchar区别,varchar(M)能存多少

    char与varchar区别 char (13)长度固定, 如'1234567890' 存储需要空间 10个字符; varchar(13) 可变长 如'1234567890' 需要存储空间 11字符; ...

  10. web攻击之六:DNS攻击原理与防范

    随着网络的逐步普及,网络安全已成为INTERNET路上事实上的焦点,它关系着INTERNET的进一步发展和普及,甚至关系着INTERNET的生存.可喜的是我们那些互联网专家们并没有令广大INTERNE ...