centos

centos中rabbitmq集群如何搭建

小樊
53
2025-08-30 18:40:50
栏目: 智能运维

在CentOS系统中搭建RabbitMQ集群,可以按照以下步骤进行:

1. 安装Erlang

RabbitMQ是用Erlang编写的,因此首先需要安装Erlang。

# 添加Erlang解决方案库
sudo yum install -y epel-release

# 安装Erlang
sudo yum install -y erlang

2. 安装RabbitMQ

接下来安装RabbitMQ服务器。

# 添加RabbitMQ解决方案库
sudo tee /etc/yum.repos.d/rabbitmq.repo <<EOF
[rabbitmq-server]
name=RabbitMQ repository for CentOS/\$basearch
baseurl=https://packagecloud.io/rabbitmq/rabbitmq-server/el/\$releasever/\$basearch
repo_gpgcheck=1
enabled=1
gpgcheck=1
gpgkey=https://packagecloud.io/rabbitmq/rabbitmq-server/gpgkey
EOF

# 安装RabbitMQ服务器
sudo yum install -y rabbitmq-server

3. 启动并启用RabbitMQ服务

启动RabbitMQ服务并设置为开机自启。

sudo systemctl start rabbitmq-server
sudo systemctl enable rabbitmq-server

4. 配置RabbitMQ集群

假设你有三台服务器,分别是node1, node2, node3

在第一台服务器上配置集群

# 启用管理插件
sudo rabbitmq-plugins enable rabbitmq_management

# 添加节点到集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app

在第二台和第三台服务器上配置集群

在第二台和第三台服务器上执行以下命令:

# 停止RabbitMQ服务
sudo systemctl stop rabbitmq-server

# 重置RabbitMQ配置
sudo rabbitmqctl reset

# 加入集群
sudo rabbitmqctl join_cluster rabbit@node1

# 启动RabbitMQ服务
sudo systemctl start rabbitmq-server

5. 验证集群状态

在任意一台服务器上运行以下命令来验证集群状态:

sudo rabbitmqctl cluster_status

你应该能看到所有节点都加入到集群中。

6. 配置镜像队列(可选)

为了提高集群的可用性,可以配置镜像队列。

# 在任意节点上执行
sudo rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'

这条命令会将所有队列设置为镜像队列,确保在任意节点故障时,队列数据不会丢失。

7. 配置防火墙

确保防火墙允许RabbitMQ的默认端口(5672)和HTTP管理界面端口(15672)。

sudo firewall-cmd --permanent --zone=public --add-port=5672/tcp
sudo firewall-cmd --permanent --zone=public --add-port=15672/tcp
sudo firewall-cmd --reload

8. 访问管理界面

打开浏览器,访问http://<node_ip>:15672,使用默认用户名和密码(guest/guest)登录管理界面,可以查看和管理集群状态。

通过以上步骤,你就可以在CentOS系统上成功搭建一个RabbitMQ集群。

0
看了该问题的人还看了