在CentOS上搭建RabbitMQ集群需要遵循以下步骤:
RabbitMQ是用Erlang编写的,因此首先需要在所有节点上安装Erlang。
# 添加Erlang解决方案库
sudo yum install -y epel-release
# 安装Erlang
sudo yum install -y erlang
在所有节点上安装RabbitMQ服务器。
# 添加RabbitMQ解决方案库
sudo tee /etc/yum.repos.d/rabbitmq.repo <<EOF
[rabbitmq-server]
name=RabbitMQ repository for CentOS/\$basearch
baseurl=http://packagecloud.io/rabbitmq/rabbitmq-server/el/\$releasever/\$basearch
repo_gpgcheck=1
enabled=1
gpgcheck=1
gpgkey=https://packagecloud.io/gpg.key
EOF
# 安装RabbitMQ
sudo yum install -y rabbitmq-server
在所有节点上启动RabbitMQ服务,并设置为开机自启。
sudo systemctl start rabbitmq-server
sudo systemctl enable rabbitmq-server
RabbitMQ集群节点之间需要共享一个Erlang 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 chmod 400 /var/lib/rabbitmq/.erlang.cookie
为了方便管理,可以启用RabbitMQ的管理插件。
sudo rabbitmq-plugins enable rabbitmq_management
假设你有三个节点:node1, node2, node3。
# 停止RabbitMQ服务
sudo systemctl stop rabbitmq-server
# 将第一个节点加入到集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app
# 停止RabbitMQ服务
sudo systemctl stop rabbitmq-server
# 将其他节点加入到集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app
在任意一个节点上运行以下命令来验证集群状态。
sudo rabbitmqctl cluster_status
你应该能看到所有节点都在集群中,并且状态正常。
为了提高消息的可靠性,可以配置镜像队列。
# 在任意一个节点上启用镜像队列策略
sudo rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'
这样,所有队列都会被镜像到所有节点。
通过以上步骤,你可以在CentOS上成功搭建一个RabbitMQ集群。确保所有节点上的Erlang cookie一致,并且正确配置了集群和镜像队列,以保证高可用性和消息的可靠性。