安装Rabbitmq

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 扩展

配置文件路径

rabbitmq.conf.example

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-*

推荐阅读更多精彩内容