RabbitMQ | HAProxy - 给 RabbitMQ集群 集成负载均衡

文章目录

  • HAProxy
    • 概述
    • [Docker 部署 HAProxy](#Docker 部署 HAProxy)
    • [Spring AMQP 集成](#Spring AMQP 集成)

HAProxy


概述

1)试想一个问题:当 RabbitMQ 一个集群中有 3 个节点时,我们写代码时,因该访问哪个节点呢?

当然时任意一个节点都可以~

但是存在几个问题:

  • 如果配置文件中写死访问的是 node1,但是 node1 挂了,不就是变相的等于 mq集群 整体不可用了吗,所以最好是有一个统一的入口,一个节点故障时,流量可以及时转移到其他节点.
  • 如果所有客户端都和 node1 建立连接,那么 node1 的负担会大大增加,而其他节点的负担不大导致资源浪费.

2)使用 HAProxy 就可以实现流量的负载均衡.

HAProxy(High Availability Proxy)是一个开源的负载均衡和 TCP/HTTP 应用程序的代理服务器,它可以提供高可用,负载均衡和代理功能. HAProxy 主要用于分发网络流量到多个后台服务器,以提高网络的可靠性和性能.

例如 RabbitMQ,将来我们只需要在 SpringBoot 项目中配置 RabbitMQ 的连接地址为 HAProxy 配置的地址,那么所有 SpringBoot 访问请求都会先经过 HAProxy ,然后再由 HAProxy 分发给 MQ 集群中的不同实例.

Docker 部署 HAProxy

1)镜像

bash 复制代码
docker pull haproxy:3.0.3

2)vim 编辑 ~/env/haproxy/conf/haproxy.cfg 配置文件(将来挂载的配置文件)

cfg 复制代码
# haproxy web 管理界面
listen stats # 设置一个监听器,统计 HAProxy 的统计信息
    bind *:8100 # 指定监听器的 ip 和 port
    mode http # 监听器的工作模式为 HTTP
    stats enable # 启用统计页面
    stats realm HAProxy\ Statistics
    stats uri /
    stats auth root:1111 # haproxy 登录账号和密码

# 配置 mq 负载均衡
listen rabbitmq # 设置监听器
    bind *:5670 # 监听器绑定 ip 和 port,将来 SpringBoot 访问 mq 就是这个 ip 和 端口
    mode tcp # 因为 rabbitmq 使用 amqp 协议时基于 tcp 的
    balance roundrobin # 负载均衡策略: 轮询
    # 集群节点配置,这里使用 rabbit 节点
    server rabbitmq1 100.112.226.113:5672 check inter 5000 rise 2 fall 3
    server rabbitmq2 100.112.226.113:5673 check inter 5000 rise 2 fall 3
    server rabbitmq3 100.112.226.113:5674 check inter 5000 rise 2 fall 3
    # rabbitmq1、2、3 时自定义的
    # check... 是健康检测相关

3)启动

bash 复制代码
docker run -d \
--name haproxy \
-p 28100:8100 \
-p 25670:5670 \
-v ~/env/haproxy/conf/haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg \
haproxy:3.0.3

这些端口是与上面编写的配置文件一一对应的:

  • -p 28100:8100: 配置文件中配置的 web 端口,将来通过这个端口就可以访问到 HAProxy Web控制台.
  • -p 25670:5670:SpringBoot 配置文件中的 RabbitMQ 端口将来就写这个,HAProxy 就会将这些流量进行分发到集群的各个节点.
  • /usr/local/etc/haproxy/haproxy.cfg:容器内的配置文件地址不一定是这个,会随着镜像的版本变化而变化,如果容器启动失败,看一下日志就知道了.

4)访问 http://env-base:18100/ 就可以看到管理界面

人家直接连健康检测都配置好了~

Spring AMQP 集成

1)把 rabbitmq 端口改成 haproxy 的即可,haproxy 就会自动将收到的流量做分流.

yml 复制代码
spring:
  application:
    name: rabbitmq
  rabbitmq:
    host: env-base
    port: 15670 # HAProxy 监听器端口
    username: root
    password: 1111

2)队列配置

kotlin 复制代码
@Configuration
class QuorumConfig {

    @Bean
    fun quorumQueue(): Queue = QueueBuilder
        .durable(MQConst.QUORUM_QUEUE)
        .quorum()
        .build()

}

3)生产者接口

kotlin 复制代码
@RestController
@RequestMapping("/mq")
class MQApi(
    private val rabbitTemplate: RabbitTemplate
) {

    @GetMapping
    fun quorum(): String {
        rabbitTemplate.convertAndSend("", MQConst.QUORUM_QUEUE, "quorum msg 1")
        return "ok"
    }

}

4)将来无论哪个 mq 宕机,只有有一个实例还在运行,就可以提供服务.

例如如下 mq3 为 Leader

现在手动让 mq3 宕机,然后触发生产者接口,最后查看 HAProxy 管理平台,可以看到流量分发的 mq2 上了

现在手动让 mq2 宕机,然后触发生产者接口(由于是轮询策略,因此可能会服务器报错,不过没关系,多触发几次,就会将流量分到可用的机器上),最后查看 HAProxy 管理平台,可以看到流量分发的 mq1 上了

Ps:但是一定要确保 HAProxy 为可用,因此建议 HAProxy 也配置为集群.

相关推荐
用户8307196840821 天前
RabbitMQ vs RocketMQ 事务大对决:一个在“裸奔”,一个在“开挂”?
后端·rabbitmq·rocketmq
初次攀爬者2 天前
RabbitMQ的消息模式和高级特性
后端·消息队列·rabbitmq
初次攀爬者4 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
大大水瓶5 天前
HAProxy 从入门到实战:负载均衡与流量管理全解析
运维·负载均衡
让我上个超影吧5 天前
消息队列——RabbitMQ(高级)
java·rabbitmq
塔中妖5 天前
Windows 安装 RabbitMQ 详细教程(含 Erlang 环境配置)
windows·rabbitmq·erlang
屎到临头想搅便5 天前
keepalived
负载均衡
断手当码农5 天前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
雨落花开3235 天前
服务器集群,负载均衡,CDN简介
运维·服务器·负载均衡
初次攀爬者5 天前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端