1. 用戶管理
用戶管理包括增加用戶,刪除用戶,查看用戶列表,修改用戶密碼。
相應(yīng)的命令
(1) 新增一個(gè)用戶
rabbitmqctl add_user Username Password
(2) 刪除一個(gè)用戶
rabbitmqctl delete_user Username
(3) 修改用戶的密碼
rabbitmqctl change_password Username Newpassword
(4) 查看當(dāng)前用戶列表
rabbitmqctl list_users
- 用戶角色
按照個(gè)人理解,用戶角色可分為五類,超級(jí)管理員, 監(jiān)控者, 策略制定者, 普通管理者以及其他。
(1) 超級(jí)管理員(administrator)
可登陸管理控制臺(tái)(啟用management plugin的情況下),可查看所有的信息,并且可以對(duì)用戶,策略(policy)進(jìn)行操作。
(2) 監(jiān)控者(monitoring)
可登陸管理控制臺(tái)(啟用management plugin的情況下),同時(shí)可以查看rabbitmq節(jié)點(diǎn)的相關(guān)信息(進(jìn)程數(shù),內(nèi)存使用情況,磁盤使用情況等)

(3) 策略制定者(policymaker)
可登陸管理控制臺(tái)(啟用management plugin的情況下), 同時(shí)可以對(duì)policy進(jìn)行管理。但無法查看節(jié)點(diǎn)的相關(guān)信息(上圖紅框標(biāo)識(shí)的部分)。

- 與administrator的對(duì)比,administrator能看到這些內(nèi)容

(4) 普通管理者(management)
僅可登陸管理控制臺(tái)(啟用management plugin的情況下),無法看到節(jié)點(diǎn)信息,也無法對(duì)策略進(jìn)行管理。
(5) 其他
無法登陸管理控制臺(tái),通常就是普通的生產(chǎn)者和消費(fèi)者。
了解了這些后,就可以根據(jù)需要給不同的用戶設(shè)置不同的角色,以便按需管理。
設(shè)置用戶角色的命令為:
rabbitmqctl set_user_tags User Tag
User為用戶名, Tag為角色名(對(duì)應(yīng)于上面的administrator,monitoring,policymaker,management,或其他自定義名稱)。
也可以給同一用戶設(shè)置多個(gè)角色,例如
rabbitmqctl set_user_tags hncscwc monitoring policymaker
- 用戶權(quán)限
用戶權(quán)限指的是用戶對(duì)exchange,queue的操作權(quán)限,包括配置權(quán)限,讀寫權(quán)限。配置權(quán)限會(huì)影響到exchange,queue的聲明和刪除。讀寫權(quán)限影響到從queue里取消息,向exchange發(fā)送消息以及queue和exchange的綁定(bind)操作。
例如: 將queue綁定到某exchange上,需要具有queue的可寫權(quán)限,以及exchange的可讀權(quán)限;向exchange發(fā)送消息需要具有exchange的可寫權(quán)限;從queue里取數(shù)據(jù)需要具有queue的可讀權(quán)限。詳細(xì)請(qǐng)參考官方文檔中"How permissions work"部分。
相關(guān)命令為:
(1) 設(shè)置用戶權(quán)限
rabbitmqctl set_permissions -p VHostPath User ConfP WriteP ReadP
(2) 查看(指定hostpath)所有用戶的權(quán)限信息
rabbitmqctl list_permissions [-p VHostPath]
(3) 查看指定用戶的權(quán)限信息
rabbitmqctl list_user_permissions User
(4) 清除用戶的權(quán)限信息
rabbitmqctl clear_permissions [-p VHostPath] User
開啟用戶遠(yuǎn)程訪問
默認(rèn)情況下,RabbitMQ的默認(rèn)的guest用戶只允許本機(jī)訪問, 如果想讓guest用戶能夠遠(yuǎn)程訪問的話,只需要將配置文件中的loopback_users列表置為空即可,如下:
{loopback_users, []}
另外關(guān)于新添加的用戶,直接就可以從遠(yuǎn)程訪問的,如果想讓新添加的用戶只能本地訪問,可以將用戶名添加到上面的列表, 如只允許admin用戶本機(jī)訪問。
{loopback_users, ["admin"]}