rabbitMQ 高可用

如何实现RabbitMQ高可用

我们先搭建一个普通集群模式,在这个模式基础上再配置镜像模式实现高可用,Rabbit集群前增加一个反向代理,生产者、消费者通过反向代理访问RabbitMQ集群

在一个集群里,有4台机器,其中1台使用磁盘模式,另2台使用内存模式

2台内存模式的节点,无疑速度更快,因此客户端(consumer、producer)连接访问它们

磁盘模式的节点,由于磁盘IO相对较慢,因此仅作数据备份使用

一台作为反向代理

负载均衡器会监听5672端口,轮询我们的两个内存节点172.16.3.7、172.16.3.8的5672端口,172.16.3.2为磁盘节点,只做备份不提供给生产者、消费者使用

如果我们服务器资源充足情况也可以配置多个磁盘节点,这样磁盘节点出了故障也不会影响,除非同时出故障。

使用Rabbit镜像功能,需要基于rabbitmq策略来实现,政策是用来控制和修改群集范围的某个vhost队列行为和Exchange行为在cluster中任意节点启用策略,策略会自动同步到集群节点

rabbitmqctl set_policy -p hrsystem ha-allqueue "^" '{"ha-mode":"all"}'

这行命令在vhost名称为hrsystem创建了一个策略,策略名称为ha-allqueue,策略模式为 all 即复制到所有节点,包含新增节点,策略正则表达式为 "^" 表示所有匹配所有队列名称。

例如rabbitmqctl set_policy -p hrsystem ha-allqueue "^message" '{"ha-mode":"all"}'

注意:"^message" 这个规则要根据自己修改,这个是指同步"message"开头的队列名称,我们配置时使用的应用于所有队列,所以表达式为"^"

官方set_policy说明参见

set_policy [-p vhostpath] {name} {pattern} {definition} [priority]

相关推荐
Bert.Cai12 分钟前
Linux tail命令详解
linux·运维
Francek Chen31 分钟前
【大数据存储与管理】NoSQL数据库:01 NoSQL简介
大数据·数据库·分布式·nosql
sbjdhjd38 分钟前
Docker | 核心概念科普 + 保姆级部署
linux·运维·服务器·docker·云原生·面试·eureka
charlie11451419139 分钟前
嵌入式C++教程实战之Linux下的单片机编程(9):HAL时钟使能 —— 不开时钟,外设就是一坨睡死的硅
linux·开发语言·c++·单片机·嵌入式硬件·c
以太浮标41 分钟前
华为eNSP模拟器综合实验之- DHCP、DNS、HTTP和FTP服务器配置案例Client-Server
linux·服务器·windows·http·华为·信息与通信
摇滚侠1 小时前
Vmvare 虚拟机安装 Linux CentOS 7 操作系统 一键安装 Docker 1Panel 一键安装 MySQL Redis OpenClaw
linux·docker·centos
路溪非溪1 小时前
如何使用procfs来排查问题
linux·arm开发·驱动开发
帕里亚1 小时前
ubuntu18.04 APT升级 glibc2.28 (Jetson)
linux·运维·windows
好运的阿财1 小时前
“锟斤拷”问题——程序中用powershell执行命令出现中文乱码的解决办法
linux·前端·人工智能·机器学习·架构·编辑器·vim
cyber_两只龙宝1 小时前
【Nginx】Nginx实现FastCGI详解
linux·运维·nginx·云原生·php·memcached·fastcgi