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


变回蓝色

相关推荐
Asurplus14 分钟前
【RabbitMQ】5、RabbitMQ中启用MQTT功能
mqtt·消息队列·rabbitmq·订阅主题
攀小黑1 小时前
docker 部署rabbitmq消息队列并安装延迟队列插件
docker·容器·rabbitmq
熏鱼的小迷弟Liu2 小时前
【消息队列】RabbitMQ的交换机有哪几种类型?
消息队列·rabbitmq
刘一说3 小时前
Spring Cloud微服务中的分布式追踪:从故障定位到性能优化的革命性实践
分布式·spring cloud·微服务
程序员agions6 小时前
Node.js 爬虫实战指南(三):分布式爬虫架构,让你的爬虫飞起来
分布式·爬虫·node.js
回家路上绕了弯7 小时前
Spring Boot多数据源配置实战指南:从选型到落地优化
分布式·后端
小雨下雨的雨8 小时前
Flutter鸿蒙共赢——生命之痕:图灵图样与反应-扩散方程的生成美学
分布式·flutter·华为·交互·harmonyos·鸿蒙系统
利刃大大9 小时前
【RabbitMQ】SpringBoot整合RabbitMQ:工作队列 && 发布/订阅模式 && 路由模式 && 通配符模式
java·spring boot·消息队列·rabbitmq·java-rabbitmq
用户2190326527359 小时前
SpringCloud分布式追踪深度实战:Sleuth+Zipkin从入门到生产部署全攻略
分布式·后端·spring cloud