rabbitmq集群和负载均衡

1.集群

当单台RabbitMQ服务器无法满足消息的吞吐量及安全性要求时,需要搭建RabbitMQ集群

bash 复制代码
# 关闭RabbitMQ服务
rabbitmqctl stop

重新设置服务

bash 复制代码
# 设置服务一
RABBITMQ_NODE_PORT=5673 RABBITMQ_NODENAME=rabbit1 rabbitmq-server start -detached
​
​
# 设置服务二
RABBITMQ_NODE_PORT=5674 RABBITMQ_SERVER_START_ARGS="-rabbitmq_management listener [{port,15674}]" RABBITMQ_NODENAME=rabbit2 rabbitmq-server start -detached
​
​
# 关闭服务2
rabbitmqctl -n rabbit2 stop_app
# 重新设置服务2
rabbitmqctl -n rabbit2 re
# 将服务2加入服务1中
rabbitmqctl -n rabbit2 join_cluster rabbit1@localhost
# 启动服务2
rabbitmqctl -n rabbit2 start_app

集群虽然搭建成功

但是队列只保存在了一个节点中,如果该节点故障,则会丢失整个集群信息

此时我们需要引入镜像队列机制,它可以将队列消息复制到集群中的其他节点上

在控制台上切换到ADMIN界面,新增一个policy

definition新增ha-mode=all

保存即可

2.负载均衡

无论生产者还是消费者,只能链接一个rabbitmq节点,如果只链接一个节点,就会造成单个节点压力过大。此时就需要haproxy负载工具

bash 复制代码
yum -y install haproxy
vim /etc/haproxy/haproxy.cfg
bash 复制代码
# 以下为添加内容
listen rabbitmq_cluster
        # 对外暴露端口
     bind 0.0.0.0:5672
     mode tcp
     balance roundrobin
     # 代理RabbitMQ的端口
     server node1 192.168.1.196:5672 check inter 5000 rise 2 fall 2
     server node2 192.168.1.195:5672 check inter 5000 rise 2 fall 2
​
​
listen stats
        # Haproxy控制台路径
     bind 192.168.1.195:8100
     mode http
     option httplog
     stats enable
     stats uri /rabbitmq-stats
     stats refresh 5s
​
# 启动
haproxy -f /etc/haproxy/haproxy.cfg

生产者或者消费者连接rabbitmq,需要链接负载工具的地址

java 复制代码
 connectionFactory.setHost("192.168.1.195");
相关推荐
开心码农1号7 小时前
Java rabbitMQ如何发送、消费消息、全套可靠方案
java·rabbitmq·java-rabbitmq
小白学大数据8 小时前
Scrapy 分布式爬虫:大规模采集汽车之家电车评论
开发语言·分布式·爬虫·scrapy
仗剑_走天涯9 小时前
hadoop reduce阶段 对象重用问题
大数据·hadoop·分布式
电磁脑机9 小时前
无总线场同步:意识本质、AGI困境与脑机革命的核心理论重构
分布式·神经网络·架构·信号处理·agi
leo_messi949 小时前
RabbitMq(五) -- SpringBoot整合 RabbitMQ 完整实现
spring boot·rabbitmq·java-rabbitmq
半桶水专家10 小时前
kafka数据删除策略详解
分布式·kafka
一个有温度的技术博主10 小时前
Lua语法进阶:函数封装与条件控制的艺术
redis·分布式·缓存·lua
无心水10 小时前
2、5分钟上手|PyPDF2 快速提取PDF文本
java·linux·分布式·后端·python·架构·pdf
Jackyzhe10 小时前
从零学习Kafka:位移与高水位
分布式·学习·kafka
roman_日积跬步-终至千里10 小时前
【系统架构师-案例题-分布式数据缓存架构】22年下(3)分布式仓储货物管理系统
分布式·缓存·系统架构