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");
相关推荐
2501_9418227536 分钟前
互联网+教育:数字化转型推动教育公平与质量提升
rabbitmq
2501_941807262 小时前
人工智能与自动化:重塑未来工作与社会结构
rabbitmq
2501_941820492 小时前
区块链技术在不同行业中的应用与挑战:从金融到供应链的数字化革新
rabbitmq
2501_941404315 小时前
虚拟现实与增强现实:颠覆行业的沉浸式体验
rabbitmq
debug骑士5 小时前
虚拟现实的未来:重新定义体验与互动的边界
rabbitmq
WHFENGHE5 小时前
输电线路分布式故障定位在线监测装置:技术解析与实际应用价值
分布式
BD_Marathon7 小时前
【Kafka】
分布式·kafka
FinTech老王7 小时前
集中式 vs 分布式数据库:金融用户如何选择?——金仓数据库的双架构实践与选型指南
数据库·分布式·金融
2501_941882488 小时前
多维度应用架构演进驱动互联网产业创新实现业务增长与研发效能同步提升实践案例分析与趋势研究
rabbitmq
2501_941803628 小时前
5G时代的到来:推动智能城市与物联网的革命
rabbitmq