10 分钟搞定 RabbitMQ 高可用:HAProxy 负载均衡实战指南

在分布式系统中,RabbitMQ作为常用消息中间件,集群部署是保障高可用的关键。但很多开发者会遇到一个棘手问题:Java程序直接绑定RabbitMQ节点的IP和端口后,一旦该节点宕机,程序就会连接失败,只能手动修改配置恢复。

HAProxy负载均衡技术,能完美解决这个痛点——既实现请求分流,又能自动故障转移,为RabbitMQ集群搭建可靠的统一访问入口。今天就带大家一步步完成从安装到实战验证的全流程。

一、为什么一定要用HAProxy?

RabbitMQ集群即便配置了仲裁队列保证队列高可用,仍有两个核心问题:

  1. 单点依赖风险:程序绑定固定节点端口(默认5672),节点宕机直接抛出java.net.ConnectException,无法自动切换

  2. 资源浪费严重:所有请求集中在一个节点,导致该节点过载,其他节点却闲置

HAProxy的核心价值就是:作为集群“大门”,分散请求到各个节点,同时实时监控节点状态,故障时自动切换,无需手动改代码。

二、HAProxy快速安装(Ubuntu环境)

1. 更新软件源
apt-get update
2. 安装HAProxy

先查看可用版本:

apt list | grep haproxy

执行安装命令:

apt-get install haproxy
3. 验证安装

查看服务状态(显示active则成功):

systemctl status haproxy

设置开机自启:

systemctl enable haproxy

查看版本信息:

haproxy -v

三、关键配置:HAProxy核心参数设置

HAProxy配置文件路径:/etc/haproxy/haproxy.cfg,用vim编辑即可。

1. 完整配置代码(直接复制)
# 编辑配置文件 vim /etc/haproxy/haproxy.cfg

在文件末尾追加以下内容:

# HAProxy Web管理界面(方便监控) listen stats bind *:8100 # 管理界面端口 mode http # 工作模式 stats enable # 启用统计功能 stats realm Haproxy Statistics stats uri / # 访问路径 stats auth admin:admin # 登录账号密码(可自定义) # RabbitMQ负载均衡核心配置 listen rabbitmq bind *:5670 # 集群统一访问端口(避开5672默认端口) mode tcp # AMQP基于TCP协议,必须设为TCP模式 balance roundrobin # 负载均衡算法:轮询(最常用) # 集群节点配置(替换为你的实际节点IP和端口) server rabbitmq1 127.0.0.1:5672 check inter 5000 rise 2 fall 3 server rabbitmq2 127.0.0.1:5673 check inter 5000 rise 2 fall 3 server rabbitmq3 127.0.0.1:5674 check inter 5000 rise 2 fall 3
2. 关键参数说明(新手必看)
  • 负载均衡算法

    • 轮询(roundrobin):按顺序分发请求,适合节点性能一致的场景

    • 加权轮询:给高性能节点分配更高权重,处理更多请求

    • 最少连接:优先转发到连接数少的节点,提升利用率

  • 健康检查参数

    • check inter 5000:每5秒检查一次节点是否可用

    • rise 2:节点故障后,连续2次检查通过恢复可用

    • fall 3:连续3次检查失败,自动移除该节点

3. 配置生效

修改后重启HAProxy:

systemctl restart haproxy

四、实战验证:负载均衡+故障转移

1. 程序连接配置修改(Java示例)

无需关注集群具体节点,只需连接HAProxy的IP和端口(5670):

spring: rabbitmq: addresses: amqp://admin:password@haproxy-ip:5670/test # 替换实际IP和密码 publisher-confirm-type: correlated listener: simple: acknowledge-mode: auto

2. 测试步骤

(1)正常场景测试

启动RabbitMQ集群和Java程序,调用接口发送消息:

@RestController @RequestMapping("/producer") public class ProducerController { @Autowired private RabbitTemplate rabbitTemplate; @RequestMapping("/test") public String test() { rabbitTemplate.convertAndSend("", "quorum.queue", "RabbitMQ+HAPorxy测试"); return "消息发送成功"; } }

访问http://127.0.0.1:8080/producer/test,消息能正常投递即成功。

(2)故障转移测试

手动停止一个RabbitMQ节点:

rabbitmqctl -n rabbit stop_app

再次调用接口,程序仍能正常发送消息,HAProxy会自动将请求转发到健康节点。

五、总结

HAProxyRabbitMQ集群带来三大核心优势:

  1. 高可用:故障自动转移,无需人工干预

  2. 高并发:请求分流,避免单点过载

  3. 易维护:集群扩容/替换节点,无需修改程序配置

这套方案适用于微服务、分布式系统等各类需要高可用消息通信的场景,新手也能快速上手。如果在配置过程中遇到问题,欢迎在评论区留言交流~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1141554.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

告别“算完就忘”:3行代码为Windows打造可审计计算器

面对复杂的四则运算,你是否也经历过对计算结果的自我怀疑?那个藏在电脑角落的批处理文件,每次运行时都在默默为你的每一步计算留下无法抵赖的铁证。 痛点:我们为什么需要“计算留痕”? 在日常工作、财务对账或工程计算…

MDK编译优化选项对C代码的影响:一文说清原理

MDK编译优化选项对C代码的影响:从原理到实战的深度剖析一个困扰无数嵌入式工程师的问题你有没有遇到过这样的场景?调试一段ADC采样代码时,明明在主循环里读取了一个由中断更新的标志变量,但程序就是“卡住”不动——断点停在那里&…

超详细版:CubeMX搭建FreeRTOS与CAN通信驱动流程

从零搭建STM32实时通信系统:CubeMX FreeRTOS CAN 驱动实战指南你有没有遇到过这样的场景?主循环里塞满了ADC采样、LED闪烁、串口打印,突然来了个CAN报文要发,结果因为某个任务卡了几十毫秒,通信直接超时。更糟的是&a…

智慧物流如何重塑云南高原农产品供应链?

📌 目录🚛 松茸24小时直达东京!华为智慧冷链改写云南山货命运:从烂半路到全球鲜,数字高铁如何逆袭?一、传统物流的“生死劫”:山货出山,一半耗在半路(一)核心…

Multisim参数扫描分析:深度剖析其配置技巧

Multisim参数扫描分析实战:从入门到精通的深度指南你有没有过这样的经历?为了调出一个理想的滤波器响应,手动改了十几遍电容值,每次都要重新运行仿真、切换窗口对比曲线,最后不仅眼睛累,还漏掉了关键的转折…

计算机毕设 java 基于 Java 的武夷智能公交系统的设计与实现 智能公交信息管理平台 城市公交路线查询系统

计算机毕设 java 基于 Java 的武夷智能公交系统的设计与实现 d60429(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享随着城市交通的快速发展和居民出行需求的提升,传统公交管理存在…

HardFault_Handler异常响应流程:图解说明与调试

深入HardFault:从崩溃现场还原真相的实战指南在嵌入式开发的世界里,最让人又爱又恨的一幕莫过于程序突然“挂掉”,调试器一连串断点失效,最终停在一个名为HardFault_Handler的函数入口。它像一道无声的警报——系统出了大问题。但…

计算机毕设 java 基于 Java 的物业管理系统 智能小区物业管控平台 业主服务管理系统

计算机毕设 java 基于 Java 的物业管理系统 97wd59(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享随着城市化进程的加快和小区管理需求的提升,传统物业管理存在流程繁琐、信息传递…

【AI+教育】一文读懂STEM与STEAM:不止多一个“A”的教育差异

一文读懂STEM与STEAM:不止多一个“A”的教育差异 在当下的教育领域,STEM和STEAM是两个高频出现的概念,它们都是面向未来的跨学科教育理念,旨在培养复合型人才。很多人会误以为两者完全相同,实则STEAM是STEM的延伸与发展,核心差异在于是否融入“艺术”元素。今天,我们就…

强化学习算法

摘要:强化学习算法是一类通过环境交互优化决策的机器学习方法,分为基于模型和无模型两种类型。基于模型算法(如动态规划、蒙特卡洛树搜索)先构建环境模型进行预测,具有较高样本效率但计算复杂;无模型算法&a…

计算机毕设 java 基于 Java 的蛋糕甜品商城的设计与实现 甜品线上商城管理系统 烘焙甜品销售平台

计算机毕设 java 基于 Java 的蛋糕甜品商城的设计与实现 mmt9u9(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享随着互联网的普及和消费模式的升级,传统蛋糕甜品销售存在线下门店辐…

Keil生成Bin文件与底层驱动兼容性问题深度剖析

Keil生成Bin文件与底层驱动兼容性问题深度剖析从一个“神秘”的ADC故障说起上周三晚上十点,我收到产线同事的紧急消息:“新烧录的固件上电后ADC一直返回0,但用J-Link调试时一切正常。”这听起来像是典型的“薛定谔式Bug”——代码没错、逻辑通…

Day 08:【99天精通Python】列表推导式与元组 - 进阶技巧与不可变序列

Day 08:【99天精通Python】列表推导式与元组 - 进阶技巧与不可变序列 前言 欢迎来到第8天! 在昨天的课程中,我们掌握了Python中最常用的数据结构——列表(List)的基础用法。你可能已经发现,用for循环来处理…

Proteus8.9下载安装教程:新手快速理解安装要点

请提供您需要润色优化的博文内容,我将根据上述详尽的编辑准则对其进行深度重构与提升。

CCS使用小白指南:常见安装问题解决方案

CCS使用实战指南:从零搭建稳定开发环境 你是不是也经历过这样的场景? 刚下载好TI的Code Composer Studio(CCS),满怀期待地点开安装包,结果弹出一堆错误提示——驱动装不上、Java报错、许可证激活失败………

STM32上手ModbusTCP:新手教程从零开始

从零开始在 STM32 上实现 ModbusTCP 通信:手把手实战指南 你是不是也遇到过这样的场景?项目需要让一个嵌入式设备和上位机、HMI 或 PLC 打通数据,但各家协议五花八门,开发起来头疼。这时候, ModbusTCP 就成了那个“万…

Redis集群:原理与实战经验分享(面试必看!)

文章目录是否使用过 Redis 集群?集群的原理是什么?**1. 是否使用过 Redis 集群?****Redis 集群是什么?****为什么需要 Redis 集群?****2. Redis 集群的原理是什么?****2.1 数据分片(Sharding&am…

基于Java+SpringBoot+SSM物流管理系统(源码+LW+调试文档+讲解等)/物流管理软件/物流信息管理系统/供应链物流管理系统/企业物流管理系统/物流仓储管理系统/智能物流管理系统

博主介绍 💗博主介绍:✌全栈领域优质创作者,专注于Java、小程序、Python技术领域和计算机毕业项目实战✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 2025-2026年最新1000个热门Java毕业设计选题…

工业传感器采集系统Keil5环境搭建手把手教程

手把手教你搭建工业传感器采集系统的Keil5开发环境 在工厂的自动化产线上,你是否见过那些默默工作的“电子耳目”?温度探头实时监测炉温,振动传感器预警设备故障,压力变送器确保管道安全——这些数据的第一站,往往不是…

计算机毕设 java 基于 JAVA 的网上订餐系统的设计与实现 智能餐饮订餐平台 线上菜品订购管理系统

计算机毕设 java 基于 JAVA 的网上订餐系统的设计与实现 sa1209(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享随着生活节奏的加快和线上服务的普及,用户对便捷、高效的订餐渠道需…