1. 安装erlang
1.1 创建Yum源
$ sudo vi /etc/yum.repos.d/rabbitmq-erlang.repo
# 文件内容
[rabbitmq-erlang]
name=rabbitmq-erlang
baseurl=https://dl.bintray.com/rabbitmq-erlang/rpm/erlang/22/el/7
gpgcheck=1
gpgkey=https://dl.bintray.com/rabbitmq/Keys/rabbitmq-release-signing-key.asc
repo_gpgcheck=0
enabled=1
参考:https://github.com/rabbitmq/erlang-rpm#bintray-yum-repositories
1.2 安装
$ sudo yum install -y erlang
1.3 验证
# 进入erlang命令行表示成功
$ erl
rlang/OTP 22 [erts-10.4] [source] [64-bit] [smp:4:4] [ds:4:4:10] [async-threads:1] [hipe]
Eshell V10.4 (abort with ^G)
2. 安装socat
$ sudo yum install -y socat
3. 安装rabbitmq
3.1 安装
$ sudo rpm -Uvh https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.7.15/rabbitmq-server-3.7.15-1.el7.noarch.rpm
下载链接参考:https://www.rabbitmq.com/install-rpm.html#downloads
3.2 启动rabbitmq服务
# 启动服务
$ sudo systemctl start rabbitmq-server
# 停止服务
$ sudo systemctl stop rabbitmq-server
# 查看状态
$ sudo systemctl status rabbitmq-server
# 设置为开机启动
$ sudo systemctl enable rabbitmq-server
3.3 rabbitmq 配置
3.3.1 添加管理配置插件
# 安装web管理页面插件(先启动rabbitmq服务):
$ sudo rabbitmq-plugins enable rabbitmq_management
3.3.2 添加用户并授权
# 添加用户
$ sudo rabbitmqctl add_user admin password
# 设置用户角色
# user role list: administrator,monitoring,policymaker,management
$ sudo rabbitmqctl set_user_tags admin administrator
# 设置用户权限(接受来自所有Host的所有操作)
# set_permissions [-p vhost] {user} {conf} {write} {read}
$ sudo rabbitmqctl set_permissions -p "/" admin '.*' '.*' '.*'
# 查看用户权限
$ sudo rabbitmqctl list_user_permissions admin
3.4 开放端口
若有需要,还需要开放端口。
# 开放端口
$ sudo firewall-cmd --add-port=5672/tcp --permanent
# 重新加载防火墙配置
$ sudo firewall-cmd --reload
3.5 删除默认用户或修改密码
# 删除guest用户
$ sudo rabbitmqctl delete_user guest
# 修改密码
$ sudo rabbitmqctl change_password guest password
# 清除密码. 清除密码后,用户无法登录.
$ sudo rabbitmqctl clear_password guest
默认情况下,RabbitMQ禁止guest用户远程访问,只可以访问本地的mq服务。这个是通过loopback_users配置项决定的,如果需要取消该限制,仅需将该选项配置为none即可:
$ sudo rabbitmqctl loopback_users = none
按照 官方的示例配置文件,如果仅需要取消guest用户本地访问限制,那么进行以下配置:
loopback_users.guest = false
4. 新版配置
4.1 语法
新版配置是从版本3.7.0
开始支持的,新版配置语法可以概括为(从官网原文翻译):
- 一行代表一个配置
- 语法结构统一为
Key = Value
- 以
#
开始的行会被解析成注释
说白了就跟大多数配置文件的语法一样。。。
4.2 文件后缀名
旧版本配置文件为:/etc/rabbitmq/rabbitmq.config
,若不存在,需自己创建;
新版本配置,需要把文件后缀名改成.conf
,即/etc/rabbitmq/rabbitmq.conf
。
原文请见:config-file
4.3 扩展
5. 日志目录
$ ll /var/log/rabbitmq
total 44
drwxr-x--- 2 rabbitmq rabbitmq 42 May 31 00:00 log
-rw-r----- 1 rabbitmq rabbitmq 38828 May 31 12:13 rabbit@localhost.log
-rw-r----- 1 rabbitmq rabbitmq 198 May 31 12:13 rabbit@localhost_upgrade.log
6. RabbitMQ常用命令
# 添加用户
sudo rabbitmqctl add_user <username> <password>
# 删除用户
sudo rabbitmqctl delete_user <username>
# 修改用户密码
sudo rabbitmqctl change_password <username> <newpassword>
# 清除用户密码(该用户将不能使用密码登陆,但是可以通过SASL登陆如果配置了SASL认证)
sudo rabbitmqctl clear_password <username>
# 设置用户tags(相当于角色,包含administrator,monitoring,policymaker,management)
sudo rabbitmqctl set_user_tags <username> <tag>
# 列出所有用户
sudo rabbitmqctl list_users
# 创建一个vhosts
sudo rabbitmqctl add_vhost <vhostpath>
# 删除一个vhosts
sudo rabbitmqctl delete_vhost <vhostpath>
# 列出vhosts
sudo rabbitmqctl list_vhosts [<vhostinfoitem> ...]
# 针对一个vhosts给用户赋予相关权限;
sudo rabbitmqctl set_permissions [-p <vhostpath>] <user> <conf> <write> <read>
# 清除一个用户对vhosts的权限;
sudo rabbitmqctl clear_permissions [-p <vhostpath>] <username>
# 列出哪些用户可以访问该vhosts;
sudo rabbitmqctl list_permissions [-p <vhostpath>]
# 列出用户访问权限;
sudo rabbitmqctl list_user_permissions <username>
附录
安装完的目录在:/usr/lib/rabbitmq/lib/rabbitmq_server-*