阅读量:3
在CentOS上搭建RabbitMQ集群需要遵循以下步骤:
1. 安装Erlang
RabbitMQ是用Erlang编写的,因此首先需要在所有节点上安装Erlang。
# 添加Erlang解决方案库
sudo tee /etc/yum.repos.d/erlang.repo <<EOF
[erlang-solutions]
name=Erlang solutions repository for CentOS-$releasever
baseurl=https://packages.erlang-solutions.com/centos/$releasever/base
enabled=1
gpgcheck=1
gpgkey=https://packages.erlang-solutions.com/centos/$releasever/sgpgkey
EOF
# 安装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-$releasever - \$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. 配置Erlang Cookie
RabbitMQ使用Erlang cookie进行节点间的身份验证。确保所有节点上的Erlang cookie相同。
# 查找cookie文件位置
sudo find / -name ".erlang.cookie"
# 将cookie复制到其他节点
sudo scp /var/lib/rabbitmq/.erlang.cookie user@node2:/var/lib/rabbitmq/
sudo scp /var/lib/rabbitmq/.erlang.cookie user@node3:/var/lib/rabbitmq/
# 在每个节点上设置正确的权限
sudo chown rabbitmq:rabbitmq /var/lib/rabbitmq/.erlang.cookie
sudo chmod 400 /var/lib/rabbitmq/.erlang.cookie
5. 配置RabbitMQ集群
假设你有三个节点:node1, node2, node3。
在node1上配置集群
# 启用管理插件
sudo rabbitmq-plugins enable rabbitmq_management
# 将node2加入集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app
在node2上配置集群
# 停止RabbitMQ服务
sudo systemctl stop rabbitmq-server
# 加入集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app
在node3上配置集群
# 停止RabbitMQ服务
sudo systemctl stop rabbitmq-server
# 加入集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app
6. 验证集群状态
在任意节点上运行以下命令来验证集群状态:
sudo rabbitmqctl cluster_status
你应该能看到所有节点都加入了集群。
7. 配置镜像队列(可选)
为了提高高可用性,可以配置镜像队列。
# 在任意节点上启用镜像队列插件
sudo rabbitmq-plugins enable rabbitmq_mirroring_queue
# 配置策略
sudo rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'
这样,所有队列都会被镜像到所有节点。
8. 配置防火墙
确保防火墙允许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
完成以上步骤后,你的RabbitMQ集群应该已经成功搭建并运行。
以上就是关于“rabbitmq集群在centos上搭建”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm