rabbitmq集群在centos上怎么搭建

在CentOS上搭建RabbitMQ集群需要以下几个步骤:1. 安装ErlangRabbitMQ是用Erlang编写的,因此首先需要在所有节点上安装Erlang。# 添加Erlang解决方案库sudo tee /etc/yum.repos.d/erlang.repo <<EOF[erlang-solutions]name=Erlang solutions repository for

在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-7
baseurl=https://packages.erlang-solutions.com/erlang/rpm/centos/7/x86_64/
enabled=1
gpgcheck=1
gpgkey=https://packages.erlang-solutions.com/erlang/solutions.asc
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-7
baseurl=https://packagecloud.io/rabbitmq/rabbitmq-server/el/7/$basearch
repo_gpgcheck=1
gpgcheck=1
enabled=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相同。

# 找到Erlang 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 chmod 400 /var/lib/rabbitmq/.erlang.cookie

5. 配置RabbitMQ集群

假设你有三个节点:node1, node2, node3。

在node1上配置集群

# 启动RabbitMQ管理插件(可选)
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上配置集群

# 将node2加入node1的集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app

在node3上配置集群

# 将node3加入node1的集群
sudo rabbitmqctl stop_app
sudo rabbitmqctl reset
sudo rabbitmqctl join_cluster rabbit@node1
sudo rabbitmqctl start_app

6. 验证集群状态

在任意一个节点上运行以下命令来验证集群状态:

sudo rabbitmqctl cluster_status

你应该能看到所有节点都在集群中,并且状态为[discovered]

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

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

# 在任意一个节点上配置镜像队列策略
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集群应该已经成功搭建并运行。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请发送邮件至 55@qq.com 举报,一经查实,本站将立刻删除。转转请注明出处:https://www.szhjjp.com/n/1362714.html

(0)
派派
上一篇 2025-07-06
下一篇 2025-07-06

发表回复

登录后才能评论