rabbitmq镜像集群搭建

用到的ip地址

ip地址 端口
192.168.101.65(主) 15672
192.168.101.75 15672
192.168.101.85 15672

安装erlang和rabbitmq

安装

安装三个包

yum install esl-erlang_23.0-1_centos_7_amd64.rpm -y

yum install esl-erlang-compat-18.1-1.noarch.rpm -y

rpm -ivh rabbitmq-server-3.8.9-1.el7.noarch.rpm

启动rabbitmq和web插件

rabbitmq启动失败

复制代码
[root@rabbitmq01 rabbitmq]# journalctl -xe
8月 17 14:02:03 rabbitmq01 rabbitmq-server[27206]: {{shutdown,
8月 17 14:02:03 rabbitmq01 rabbitmq-server[27206]: 14:02:03.632 [error]                    {failed_to_start_child,auth,
8月 17 14:02:03 rabbitmq01 rabbitmq-server[27206]: 14:02:03.632 [error]                        {"Error when reading /var/lib/rabbitmq/.erlang.cookie: eacces",
8月 17 14:02:03 rabbitmq01 rabbitmq-server[27206]: {failed_to_start_child,auth,
8月 17 14:02:03 rabbitmq01 rabbitmq-server[27206]: {"Error when reading /var/lib/rabbitmq/.erlang.cookie: eacces",
8月 17 14:02:03 rabbitmq01 rabbitmq-server[27206]: [{auth,init_cookie,0,[{file,"auth.erl"},{line,290}]},

rabbitmq没有读取.erlang.cookie的权限,修改权限所有者

复制代码
chown rabbitmq:rabbitmq /var/lib/rabbitmq/.erlang.cookie

配置镜像集群

修改映射文件

复制代码
vi /etc/hosts

添加

复制代码
192.168.101.65 rabbitmq01
192.168.101.75 rabbitmq02
192.168.101.85 rabbitmq03

重启网络服务

复制代码
service network restart

修改主机名(不要在集群启动后再去修改,会让集群节点名称是根据主机名来的,中途改掉会报错)

复制代码
hostnamectl set-hostname new_hostname(rabbitmq01/0/03)

同步 rabbitmq的cookie 文件.erlang.cookie (隐藏文件,使用 ls -all 显示)

复制代码
scp /var/lib/rabbitmq/.erlang.cookie 192.168.101.75:/var/lib/rabbitmq
scp /var/lib/rabbitmq/.erlang.cookie 192.168.101.85:/var/lib/rabbitmq

75和85重启rabbitmq-server

复制代码
systemctl restart rabbitmq-server

75和85加入集群

复制代码
rabbitmqctl stop_app
rabbitmqctl join_cluster rabbit@rabbitmq01
rabbitmqctl start_app


如果中途在主节点删过从节点,但是从节点没有重置,又再次想加入主节点,会报下面的错

复制代码
[root@rabbitlocalhost miaoruntu]# rabbitmqctl join_cluster rabbit@rabbitmq01
Clustering node rabbit@rabbitlocalhost with rabbit@rabbitmq01
Error:
{:inconsistent_cluster, 'Node rabbit@rabbitmq01 thinks it's clustered with node rabbit@rabbitlocalhost, but rabbit@rabbitlocalhost disagrees'}

在从节点重置,再重新加入主节点

复制代码
rabbitmqctl stop_app
rabbitmqctl reset
rabbitmqctl join_cluster rabbit@rabbitmq01
rabbitmqctl start_app

添加用户

复制代码
rabbitmqctl add_user supeizhi 123
rabbitmqctl set_user_tags supeizhi administrator
rabbitmqctl set_permissions -p "/" supeizhi ".*" ".*" ".*"

设置镜像策略

pattern:"^queue_" 表示对队列名称以"queue_"开头的所有队列镜像,而"^"表示匹配所有的队列

definition:镜像定义,包括三个部分ha-mode, ha-params, ha-sync-mode

ha-mode:高可用模式,有效值为 all/exactly/nodes,策略模式为 all(复制到所有节点,包含新增节点)

创建队列

点击testQueue发送消息

后面蓝色的+2表示有两个消息节点,total1表示消息发送成功

将节点01停掉

复制代码
rabbitmqctl stop_app

后面蓝色变成+1没有了

将节点03停掉,后面没有从节点了

启动01和03节点(鼠标过去会显示节点未同步)

同步队列

复制代码
rabbitmqctl sync_queue testQueue


变回蓝色

相关推荐
云和数据.ChenGuang9 小时前
OpenEuler系统下RabbitMQ安装与基础配置教程
服务器·分布式·rabbitmq·ruby·数据库运维工程师·运维教程
大千AI助手13 小时前
程序合约:形式化验证中的规范与实现框架
分布式·区块链·软件开发·形式化验证·大千ai助手·程序合约·contracts
云和数据.ChenGuang14 小时前
Deepseek适配场景:OpenEuler系统下RabbitMQ安装与基础配置教程
分布式·rabbitmq·ruby
时光追逐者14 小时前
一个基于 .NET 开源、功能强大的分布式微服务开发框架
分布式·微服务·开源·c#·.net·.net core
2501_9401986915 小时前
【前瞻创想】Kurator·云原生实战派:打造下一代分布式云原生基础设施
分布式·云原生
太阳伞下的阿呆15 小时前
kafka高吞吐持久化方案(2)
分布式·kafka·高并发·重入锁
永亮同学17 小时前
【探索实战】告别繁琐,一栈统一:Kurator 从0到1落地分布式云原生应用管理平台!
分布式·云原生
十五年专注C++开发17 小时前
ZeroMQ: 一款高性能、异步、轻量级的消息传输库
网络·c++·分布式·zeroqm
张人玉18 小时前
LiveCharts WPF MVVM 图表开发笔记
大数据·分布式·wpf·livecharts
不惑_18 小时前
Kurator 分布式云原生平台从入门到实战教程
分布式·云原生