在CentOS上搭建RabbitMQ集群需要遵循以下步骤:
RabbitMQ是用Erlang编写的,因此首先需要在所有节点上安装Erlang。
# 添加Erlang解决方案库
sudo tee /etc/yum.repos.d/erlang.repo <<EOF
[erlang-solutions]
name=Erlang solutions repository for CentOS-\$releasever - \$basearch
baseurl=https://packages.erlang-solutions.com/erlang/rpm/centos/\$releasever/\$basearch
enabled=1
gpgcheck=1
gpgkey=https://packages.erlang-solutions.com/erlang/solutions.asc
EOF
# 安装Erlang
sudo yum install -y erlang
在所有节点上安装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
gpgcheck=1
enabled=1
gpgkey=https://packagecloud.io/rabbitmq/rabbitmq-server/gpgkey
EOF
# 安装RabbitMQ服务器
sudo yum install -y rabbitmq-server
在所有节点上启动RabbitMQ服务并设置开机自启。
sudo systemctl start rabbitmq-server
sudo systemctl enable rabbitmq-server
RabbitMQ集群中的所有节点必须共享相同的Erlang cookie。默认情况下,cookie文件位于/var/lib/rabbitmq/.erlang.cookie
。
在第一个节点上查看cookie:
sudo cat /var/lib/rabbitmq/.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
启用RabbitMQ的管理插件以便于监控和管理。
sudo rabbitmq-plugins enable rabbitmq_management
在第一个节点上启动RabbitMQ管理界面:
sudo rabbitmqctl status
在第二个节点上加入集群:
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@first_node
sudo rabbitmqctl start_app
将first_node
替换为第一个节点的主机名或IP地址。
在第三个节点上重复上述步骤:
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@first_node
sudo rabbitmqctl start_app
在任意一个节点上检查集群状态:
sudo rabbitmqctl cluster_status
你应该能看到所有节点都加入了集群。
为了提高高可用性,可以配置镜像队列,使得队列在多个节点上进行镜像。
sudo rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'
这将把所有队列设置为镜像队列,确保在任意一个节点故障时,队列仍然可用。
通过以上步骤,你就可以在CentOS上成功搭建一个RabbitMQ集群。