037 RabbitMQ集群

文章目录

一般来说,如果只是为了学习RabbitMQ或者验证业务工程的正确性那么在本地环境或者测试环境上使
用其单实例部署就可以了,但是出于MQ中间件本身的可靠性、并发性、吞吐量和消息堆积能力等问题
的考虑,在生产环境上一般都会考虑使用RabbitMQ的集群方案。

RabbitMQ这款消息队列中间件产品本身是基于Erlang编写,Erlang语言天生具备分布式特性(通过同步

Erlang集群各节点的magic cookie来实现)。因此,RabbitMQ天然支持Clustering。集群是保证可靠性

的一种方式,同时可以通过水平扩展以达到增加消息吞吐量能力的目的,这里只需要保证erlang_cookie

的参数一致集群即可通信。

集群搭建

bash 复制代码
# docker run 命令解释
docker run --link 可以用来链接2个容器,使得源容器(被链接的容器)和接收容器(主动去链接
的容器)之间可以互相通信。
# -p 映射一个端口
# -v 挂载数据卷
# --name为当前容器设置一个别名
# -di 启动守护式容器
# -it 启动交互式容器
# 进入容器之后执行的命令/bin/bash
# -e 设置默认参数
# --hostname 设置当前容器中虚拟机的主机名称
# --link的格式: name:hostname
# name是源容器的名称;hostname是源容器在的hostname。

启动三个RabbitMQ

bash 复制代码
# 1.1 启动RabbitMQ1
docker run -d --hostname rabbitmq1 --name=m1 -p 15673:15672 -p 5673:5672 -e
RABBITMQ_ERLANG_COOKIE='rabbitmqcookie' rabbitmq:management
# -e 注入参数,RABBITMQ_ERLANG_COOKIE: erlang_cookie参数,集群中的节点必须保持一致
# 1.2 启动RabbitMQ2
docker run -d --hostname rabbitmq2 --name=m2 -p 15674:15672 -p 5674:5672 --
link m1:rabbitmq1 -e RABBITMQ_ERLANG_COOKIE='rabbitmqcookie'
rabbitmq:management
# 1.3 启动RabbitMQ3
docker run -d --hostname rabbitmq3 --name m3 -p 15675:15672 -p 5675:5672 --
link m2:rabbitmq2 --link m1:rabbitmq1 -e
RABBITMQ_ERLANG_COOKIE='rabbitmqcookie' rabbitmq:management

进入RabbitMQ容器m1,重置rabbitmq服务

bash 复制代码
#进入myrabbiratmq1容器
docker exec -it m1 bash
#停止rabbit应用
rabbitmqctl stop_app
#重置rabbitmq
rabbitmqctl reset
#启动rabbit应用
rabbitmqctl start_app

进入RabbitMQ容器m2,加入集群:连接节点1rabbitmq服务

bash 复制代码
#3.进入myrabbitmq2容器
docker exec -it m2 bash
#停止rabbit应用
rabbitmqctl stop_app
#重置rabbitmq
rabbitmqctl reset
#加入集群
rabbitmqctl join_cluster --ram rabbit@rabbitmq1
## --ram 设置内存节点
#启动rabbit应用
rabbitmqctl start_app

进入RabbitMQ容器m3,加入集群:连接节点1rabbitmq服务

bash 复制代码
#4.进入myrabbitmq3容器
docker exec -it m3 bash
#停止rabbit应用
rabbitmqctl stop_app
#重置rabbitmq
rabbitmqctl reset
#加入集群 硬盘节点
rabbitmqctl join_cluster rabbit@rabbitmq1
#启动rabbit应用
rabbitmqctl start_app

启动完成查看集群状态

bash 复制代码
#查看集群状态
rabbitmqctl cluster_status

注意:

集群中必须至少存在一个磁盘节点!!!

集群存在问题

上述配置的RabbitMQ集群模式,并不能保证队列的高可用性,尽管交换机绑定队列的内容,可以复制

到集群里的任何一个节点,但是队列内容不会复制,队列节点宕机直接导致该队列无法应用,只能等待

节点重启,所以要想在队列节点宕机或故障也能正常应用,就要复制队列内容到集群里的每个节点,须

要创建镜像队列。

镜像队列可以同步queue和message,当主queue挂掉,从queue中会有一个变为主queue来接替工

作。

镜像队列是基于普通的集群模式的,所以你还是得先配置普通集群,然后才能设置镜像队列。

镜像队列设置后,会分一个主节点和多个从节点,如果主节点宕机,从节点会有一个选为主节点,原先

的主节点起来后会变为从节点。

bash 复制代码
#设置镜像队列命令,随便在一台节点都可以执行
rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'
相关推荐
Java 码农1 天前
RabbitMQ集群部署方案及配置指南05
分布式·rabbitmq
Java 码农1 天前
RabbitMQ集群部署方案及配置指南01
linux·服务器·rabbitmq
Overt0p1 天前
抽奖系统(6)
java·spring boot·redis·设计模式·rabbitmq·状态模式
Java 码农1 天前
RabbitMQ集群部署方案及配置指南04
分布式·rabbitmq
独自破碎E1 天前
在RabbitMQ中,怎么确保消息不会丢失?
分布式·rabbitmq
Java 码农1 天前
RabbitMQ集群部署方案及配置指南02
分布式·rabbitmq
bentengjiayou1 天前
Kafka和RabbitMQ相比有什么优势?
分布式·kafka·rabbitmq
零度@1 天前
Java 消息中间件 - RabbitMQ 全解(保姆级 2026)
java·rabbitmq·java-rabbitmq
奋进的芋圆2 天前
Java 延时任务实现方案详解(适用于 Spring Boot 3)
java·spring boot·redis·rabbitmq