Rabbitmq - 集群模式

在RabbitMQ中,一个节点的服务其实也是作为一个集群来处理的,在web控制台的admin-> cluster 中可以看到集群的名字,并且可以在页面上修改。而多节点的集群有两种方式:

默认的普通集群模式

这种模式使用Erlang语言天生具备的集群方式搭建。这种集群模式下,集群的各个节点之间只会有相同的元数据,即队列结构,而消息不会进行冗余,只存在一个节点中。
消费时,如果消费的不是存有数据的节点, RabbitMQ会临时在节点之间进行数据传输,将消息从存有数据的节点传输到消费的节点。很显然,这种集群模式的消息可靠性不是很高。因为如果其中有个节点服务宕机了,那这个节点上的数据就无法消费了,需要等到这个节点服务恢复后才能消费,而这时,消费者端已经消费过的消息就有可能给不了服务端正确应答,服务起来后,就会再次消费这些消息,造成这部分消息重复消费
另外,如果消息没有做持久化,重启就消息就会丢失。并且,这种集群模式也不支持高可用,即当某一个节点服务挂了后,需要手动重启服务,才能保证这一部分消息能正常消费。所以这种集群模式只适合一些对消息安全性不是很高的场景。
而在使用这种模式时,消费者应该尽量的连接上每一个节点,减少消息在集群中的传输

镜像模式

这种模式是在普通集群模式基础上的一种增强方案,这也就是RabbitMQ的官方HA高可用方案。需要在搭建了普通集群之后再补充搭建。其本质区别在于,这种模式会在镜像节点中间主动进行消息同步,而不是在客户端拉取消息时临时同步。
并且在集群内部有一个算法会选举产生master和slave,当一个master挂了后,也会自动选出一个来。从而给整个集群提供高可用能力。这种模式的消息可靠性更高,因为每个节点上都存着全量的消息。而他的弊端也
是明显的,集群内部的网络带宽会被这种同步通讯大量的消耗,进而降低整个集群的性能。这种模式下,队列数量最好不要过多。

实际开发环境可以通过,增加keepalived保证每个RabbitMQ的稳定性,当某一个节点上的RabbitMQ服务崩溃时,可以及时重新启动起来。另外,也可以增加HA-proxy来做前端的负载均衡,通过HA-proxy增加一个前端转发的虚
拟节点,应用可以像使用一个单点服务一样使用一个RabbitMQ集群

Rabbitmq 镜像队列设置

可以通过命令行的形式设置,也可以通过代码配置

1:指定全部节点进行镜像队列

    @Bean
    public Queue minorQueue() {
        Map<String,Object>args = new HashMap<>(2);
        //1,全部节点进行镜像队列
        args.put("x-ha-policy","all");
        return new Queue(RabbitConstant.MINOR_QUEUE,true,false,false,args);
    }

2: 指定节点进行镜像队列

@Bean
    public Queue minorQueue() {
        Map<String,Object>args = new HashMap<>(2);
        //2、指定节点进行镜像队列:
        args.put("x-ha-policy","nodes");
        args.put("x-ha-node","[rabbit@node01]");
        return new Queue(RabbitConstant.MINOR_QUEUE,true,false,false,args);
    }
<think>好的,我需要帮用户找到关于RabbitMQ集群模式安装配置的教程。根据用户提供的引用内容,我需要综合这些信息来生成一个清晰的步骤指南。首先,用户提到了四个引用,其中引用[2]和[3]提到了单机安装和集群配置的基本步骤,而引用[4]则指出每个节点需要先安装单机版并保持环境一致。引用[3]还提到了节点类型(磁盘节点和内存节点)以及集群命令的使用。 首先,我需要确认用户的需求是集群安装,所以应该分步骤说明。可能包括环境准备、单机安装、集群配置、节点类型设置、验证集群状态等。同时要注意引用中的关键点,比如每个节点必须先安装Erlang和RabbitMQ,配置文件的位置(如rabbitmq.conf在/etc/rabbitmq/),以及如何加入集群的命令。 可能需要注意的细节包括:确保所有节点的Erlang和RabbitMQ版本一致,避免兼容性问题;正确设置主机名和hosts文件,使节点之间能够互相解析;防火墙设置,开放必要的端口(如4369, 25672等);以及节点类型的选择(磁盘节点或内存节点)。引用[3]中提到使用rabbitmqctl join_cluster命令,并且可以指定--ram参数来创建内存节点,默认是磁盘节点。 另外,用户可能需要了解如何查看集群状态,如使用rabbitmqctl cluster_status命令,以及通过Web管理控制台验证集群是否正常。引用[3]和[4]都提到了这些步骤。 需要确保步骤清晰,按照逻辑顺序排列,并涵盖常见问题,比如节点无法加入集群时的检查点(如hosts文件、防火墙、cookie一致性)。同时,引用中的信息需要正确标注,例如关于配置文件的位置引用[1],集群命令引用[3],安装步骤引用[2][4]等。 最后,生成相关问题,可能涉及性能优化、高可用性配置、故障处理等,帮助用户进一步了解集群管理。例如,如何配置镜像队列,节点故障恢复步骤,或者如何扩展集群节点。</think>### RabbitMQ集群模式安装配置分步指南 --- #### 一、环境准备 1. **节点要求** - 至少2台服务器(建议3节点实现高可用) - 所有节点需保持$erlang$和$rabbitmq$版本一致[^4] - 确保节点间主机名可互相解析(需配置$hosts$文件) ```bash # 示例/etc/hosts配置 192.168.1.101 rabbitmq-node1 192.168.1.102 rabbitmq-node2 ``` 2. **防火墙设置** 开放以下端口: - $4369$(epmd端口) - $5672$(AMQP协议) - $25672$(集群通信) - $15672$(Web管理界面) --- #### 二、单机安装(所有节点执行) 1. **安装Erlang与RabbitMQ** ```bash # CentOS示例(引用[2]) yum install -y erlang yum install -y rabbitmq-server ``` 2. **启动服务并设置开机自启** ```bash systemctl enable --now rabbitmq-server ``` 3. **启用Web管理插件** ```bash rabbitmq-plugins enable rabbitmq_management ``` --- #### 三、集群配置 1. **同步Cookie文件** - 所有节点的$~/.erlang.cookie$内容必须完全一致(权限400)[^3] ```bash # 从主节点复制到其他节点 scp /var/lib/rabbitmq/.erlang.cookie root@node2:/var/lib/rabbitmq/ ``` 2. **组建集群** **以节点1为磁盘节点节点2加入集群:** ```bash # 在节点2执行(引用[3]) rabbitmqctl stop_app rabbitmqctl join_cluster rabbit@node1 --ram # --ram表示内存节点 rabbitmqctl start_app ``` 3. **验证集群状态** ```bash rabbitmqctl cluster_status ``` 输出应包含所有节点信息,类似: ```text {nodes,[{disc,['rabbit@node1']},{ram,['rabbit@node2']}]} ``` --- #### 四、高级配置 1. **节点类型管理** - 磁盘节点(disc):存储元数据到磁盘 - 内存节点(ram):仅存储元数据到内存 ```bash # 修改节点类型(需先停止服务) rabbitmqctl change_cluster_node_type disc ``` 2. **镜像队列配置** 在$rabbitmq.conf$中添加(引用[1]): ```ini ha-mode=all ha-sync-mode=automatic ``` --- #### 五、验证集群 1. **Web控制台验证** 访问$http://[节点IP]:15672$,所有节点应显示在"Nodes"列表 2. **数据同步测试** - 在任意节点创建队列 - 其他节点应自动同步该队列元数据 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员路同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值