RabbitMQ HAProxy 负载均衡

文章目录
  • 前言
  • 当Java中指定的端口号绑定的rabbitmq服务挂掉了之后,我们的程序是否还能够成功访问到rabbitmq服务呢
  • 什么是 HAProxy 负载均衡
  • HAProxy 安装
  • 修改HAProxy配置文件
  • 使用HAProxy
  • 结论

前言

前面我们学习了 rabbitmq 搭建集群,并且为了解决集群中队列的高可用问题,使用仲裁队列替代普通的队列,但是其实这里还有一个问题,就是我们在使用 Java 连接 rabbitmq 的时候,需要指定 rabbitmq 服务的 IP 和端口号,如果该端口号绑定的 rabbitmq 服务挂掉了,那么我们的 Java 程序是否还能够访问到呢?

当Java中指定的端口号绑定的rabbitmq服务挂掉了之后,我们的程序是否还能够成功访问到rabbitmq服务呢

我们 Java 程序绑定的端口号是 5672,也就是 rabbit 服务:


然后我们先将 rabbit 服务保持启动状态,并且向队列中发送消息,然后启动程序,看是否能启动成功并且成功发送消息:

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



这里是顺利启动并且成功发送消息了的,然后我们将 rabbit 服务给挂掉,再来启动 Java 程序:


启动之后,访问 127.0.0.1:8080/producer/test 向队列中发送消息:

可以发现报错了。既然这样的话是否就意味着,每次我们 Java 连接的 rabbitmq 服务挂掉之后就需要重新修改我们的代码吗?这里就可以用到我们的 HAProxy 负载均衡了。

什么是 HAProxy 负载均衡

在RabbitMQ集群中,如果所有客户端都连接到同一个节点,该节点的网络负载会显著增加,而其他节点则可能处于空闲状态,造成资源浪费。使用HAProxy作为负载均衡器,可以将客户端的连接请求分散到集群中的不同节点,实现负载均衡,从而避免单个节点过载,提高整个集群的处理能力和稳定性。HAProxy支持对后端服务器的健康检查,可以定期检测RabbitMQ集群中各个节点的可用性。一旦发现某个节点不可用,HAProxy会自动将该节点从负载均衡列表中移除,并将新的连接请求转发到其他健康的节点,确保服务的连续性和可用性。

HAProxy 安装

首先更新 apt 库:apt-get update


查找 HAProxy:apt list | grep haproxy


安装 haproxy:apt-get install haproxy


验证是否安装成功:systemctl status haproxy

查看 haproxy 版本:haproxy -v


如果要设置 haproxy 服务开机自启,可以使用:systemctl enable haproxy,关闭开启自启就是:systemctl disable haproxy

修改HAProxy配置文件

HAProxy 的配置文件默认在/etc/haproxy/haproxy.cfg路径下:


我们通过 vim 命令修改配置文件:

在这个配置文件中追加下面配置:

# haproxy web 管理界? listen stats bind *:8100 mode http stats enable stats realm Haproxy Statistics stats uri / stats auth admin:admin # 配置负载均衡 listen rabbitmq bind *:5670 mode tcp balance roundrobin 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 # haproxy web 管理界? listen stats #设置?个监听器, 统计HAProxy的统计信息 bind *:8100 #指定了监听器绑定到的IP地址和端? mode http #监听器的?作模式为HTTP stats enable #启?统计?? stats realm Haproxy Statistics stats uri / stats auth admin:admin #haproxy登录账号和密码 # 配置负载均衡 listen rabbitmq #设置监听器 bind *:5670 #监听器绑定到的IP地址和端?, 也就是集群前端IP, 供producer和consumer来进?选择,由于5672端?已经默认使?, 这?选择5670端? mode tcp #由于RabbitMQ使?AMQP协议,它是?个基于TCP的协议,所以这?使?TCP模式 balance roundrobin #指定负载均衡策略为轮询 #负载均衡中的集群节点配置,这?选择的rabbit节点 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
  • server rabbitmq1 127.0.0.1:5672 check inter 5000 rise 2 fall 3
  • server rabbitmq1:定义 RabbitMQ 服务的内部标识,这里的 rabbitmq1 是指 haproxy 内部使用的,不是指 rabbtimq 服务的节点的名称
  • 127.0.0.1:5672:RabbitMQ 真实的IP和端口
  • check inter 5000:定义每隔多少毫秒检查 RabbitMQ 服务是否可用
  • rise 2:定义 RabbitMQ 服务在发生故障之后,需要多少次健康检查才能被再次确认可用
  • fall 3:定义需要经历多少次失败的健康检查之后,HAProxy 才会停止使用此 RabbitMQ 服务

HAProxy支持多种负载均衡算法,以满足不同的应用场景和需求。在RabbitMQ集群中常用的负载均衡算法包括:

  • 轮询(Round Robin):按照顺序依次将请求分发到后端服务器。
    加权轮询(Weighted Round Robin):根据后端服务器的配置和负载情况分配不同的权重,权重高的服务器将处理更多的请求。
  • 最少连接(Least Connections):动态地选择当前连接数最少的服务器来处理新的请求,以提高后端服务的利用效率。
  • 源地址哈希(Source Hash):根据客户端的IP地址进行哈希计算,将同一IP地址的客户端请求始终转发到同一台后端服务器,以保持会话的连续性。

配置完成之后,我们重启 HAProxy 服务:systemctl restart haproxy

然后通过配置中的管理页面端口来查看管理页面:

访问到时候会提示我们输入用户名和密码,这些就是配置文件中配置的用户名和密码:

使用HAProxy

使用 HAProxy 之后的 RabbitMQ 的使用和普通的是一样的,就是需要更改我们的 Java 代码连接 rabbitmq 的 IP 和端口号为 HAProxy 的 IP 和端口号:


然后我们的 rabbit 节点还是处于挂掉的状态,我们启动程序,并且生产消息:




使用 HAProxy 就解决了 Java 代码绑定的 rabbitmq 挂掉之后,我们的 Java 程序无法连接到集群的问题了。

结论

感谢各位朋友们能够看到结尾,找不到工作?某直聘已读不回?不妨看看这里超快回复,助力每一位程序员早日找到理想的工作

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

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

相关文章

RISC架构下实时操作系统移植:项目应用

RISC架构下实时操作系统移植:从原理到实战的深度实践在工业自动化、智能驾驶和边缘计算飞速发展的今天,嵌入式系统早已不再是“跑个循环”的简单设备。越来越多的应用要求毫秒级响应、任务间精确协同、资源高效调度——这些正是实时操作系统(…

STM32在Proteus 8 Professional中的仿真可行性深度剖析

STM32能在Proteus里“跑起来”吗?——一次不绕弯的仿真实战复盘最近带学生做课程设计,又碰上了那个老问题:“老师,我还没拿到开发板,能不能先用Proteus仿真一下STM32的代码?”这问题听着简单,但…

从零开始:使用Hadoop处理物联网数据的完整指南

从零开始:使用Hadoop处理物联网数据的完整指南关键词:Hadoop、物联网数据、数据处理、分布式计算、大数据摘要:本文旨在为读者提供一份从零基础开始,使用Hadoop处理物联网数据的完整指南。首先介绍了物联网数据处理的背景和使用Ha…

CAPL实现远程诊断请求自动响应:实战案例

用CAPL打造“会说话”的虚拟ECU:远程诊断自动响应实战全解析你有没有遇到过这样的场景?新项目刚启动,硬件还没影儿,测试团队却急着要验证诊断协议;或者产线检测卡在某个负响应逻辑上,真实ECU死活不肯配合复…

Betaflight在F4飞控板上的配置优化:全面讲解

Betaflight在F4飞控板上的配置优化:从底层机制到飞行手感的全面调校 你有没有过这样的体验?——刚组装好一台穿越机,装上高端电机、轻量化机架、碳纤螺旋桨,结果一飞起来却“软绵无力”,转弯拖泥带水,油门…

永磁同步电机无差拍预测控制加延时补偿:探索高效电机控制之路

永磁同步电机无差拍预测控制加延时补偿在电机控制领域,永磁同步电机(PMSM)凭借其高功率密度、高效率等优点,广泛应用于工业、交通等众多领域。而如何实现对PMSM的精准控制,一直是研究的热点。今天咱们就来聊聊永磁同步…

[内网流媒体] 零信任理念在内网工具中的落地

零信任的核心 零信任强调“永不信任,始终验证”。即便在内网,也假设网络不可信、设备不可信、用户可能被劫持。对实时画面工具,零信任的落地关乎访问控制、最小权限和持续验证。 落地原则 身份优先 所有访问都需身份验证(口令/Token/单点登录),不提供匿名入口。 最小权…

Kafka Connect详解:大数据ETL的得力助手

Kafka Connect详解:大数据ETL的得力助手 关键词:Kafka Connect、ETL、数据管道、连接器、分布式系统、数据集成、大数据 摘要:本文将深入探讨Kafka Connect的核心概念和工作原理,这个专为Apache Kafka设计的可扩展、可靠的数据集成…

vh6501测试busoff:硬件工程师实战案例解析

vh6501测试Bus-Off:硬件工程师的实战指南从一个真实问题说起某新能源车型在路试中偶发“整车通信中断”故障,仪表黑屏、动力降级。售后排查未发现硬件损坏,日志显示BMS模块突然停止发送报文,但其他节点并未崩溃。最终定位到&#…

模拟电子技术驱动的振荡器设计:从零实现教程

从零构建一个正弦波振荡器:模拟电路的艺术与实战 你有没有试过,只用几个电阻、电容和一块运放,让电路“自己”发出稳定的正弦波?没有单片机、没有代码、也没有复杂的数字逻辑——一切全靠模拟反馈的精妙平衡。这正是 文氏桥振荡器…

Keil下载与串口烧录模式对比图解说明

Keil下载与串口烧录:从开发到量产的程序写入全解析 在嵌入式系统的世界里,代码写得再漂亮,最终也得“刷进去”才算真正落地。而如何把编译好的固件可靠、高效地写入MCU Flash,是每个工程师都绕不开的问题。 面对琳琅满目的工具和…

手把手解析74194四位移位寄存器引脚定义

从零搞懂74194:一块芯片如何让数据“左右横跳”?你有没有想过,那些会流动的LED灯、键盘扫描电路,甚至老式收音机的频道指示条,是怎么实现“一个亮完下一个亮”的?背后藏着一种看似不起眼却极为关键的数字器…

[内网流媒体] 从审计视角看内网服务设计

审计关注什么 谁在什么时候访问了什么资源; 是否有未经授权的访问; 是否符合公司安全/合规要求; 发生问题时能否追溯责任与影响范围。 关键设计点 访问日志 记录时间、IP、路径/流标识、状态码、鉴权结果、User-Agent。 按天滚动,统一时间格式,便于分析与留存。 身份与权…

七段数码管显示数字:基于STM32的硬件连接说明

从点亮一个“8”开始:深入理解STM32驱动七段数码管的底层逻辑 你有没有试过,第一次用单片机点亮一个数字时的那种兴奋? 不是OLED上绚丽的图形,也不是串口打印出的一行数据——而是当你按下复位键,那几个红红的“ 8 …

openmv与stm32通信入门必看:手把手教程(从零实现)

OpenMV与STM32通信实战指南:从零搭建视觉控制系统当你的小车开始“看见”世界想象这样一个场景:你面前的小车不需要遥控,自己就能锁定红色球并追着跑;仓库里的机械臂看到二维码就知道该往哪搬货;机器人通过手势识别理解…

操作指定目录下的文件,对特定参数赋值,接口函数

操作指定目录下的文件,对特定参数赋值,接口函数 操作 /usrdata/root/params.ini文件 并对某些参数赋值 这里为 record_stream参数赋值 #include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h>#define PARAM_FILE "…

MATLAB仿真bp神经网络预测电力负荷 商品形式:程序 实现功能:使用前几日负荷数据预测未来...

MATLAB仿真bp神经网络预测电力负荷 商品形式&#xff1a;程序 实现功能&#xff1a;使用前几日负荷数据预测未来负荷数据 使用bp神经网络 得到误差分析图电力负荷预测这活儿挺有意思的&#xff0c;咱们今天用MATLAB整点实际的。先说说思路&#xff1a;拿前7天的负荷数据当输入…

[内网流媒体] 能长期使用的内网工具具备哪些特征

长期可用性的核心要素 稳定性与可恢复 崩溃自动重启;采集/编码异常可回退;健康检查可观测。 可配置与可调优 分辨率/帧率/质量/端口/鉴权均可配置,且有安全上限。 安全与合规 默认有口令/网段限制/日志;支持审计与合规要求。 可维护与可升级 配置管理、版本化;兼容性考虑,…

Keil5开发环境搭建:手把手教程(从零配置)

Keil5开发环境搭建&#xff1a;从零开始的实战指南你有没有过这样的经历&#xff1f;买了一块崭新的STM32开发板&#xff0c;兴致勃勃地打开电脑准备“点灯”&#xff0c;结果卡在第一步——Keil打不开、编译报错一堆、下载程序失败……最后只能对着闪烁的ST-Link指示灯发呆。别…

STM32串口通信DMA传输实战案例解析

STM32串口通信DMA传输实战&#xff1a;从原理到工业级应用的深度实践在嵌入式系统开发中&#xff0c;你是否曾遇到过这样的场景&#xff1f;调试时发现CPU占用率飙升&#xff0c;但程序逻辑并不复杂&#xff1b;高波特率下接收数据频繁丢包&#xff0c;尤其在任务调度繁忙时更严…