RabbitMQ-消息队列:镜像队列、Haproxy+Keepalive 实现高可用负载均衡

23、 镜像队列

如果 RabbitMQ 集群中只有一个 Broker 节点,那么该节点的失效将导致整体服务的临时性不可用,并 且也可能会导致消息的丢失。可以将所有消息都设置为持久化,并且对应队列的durable属性也设置为true, 但是这样仍然无法避免由于缓存导致的问题:因为消息在发送之后和被写入磁盘井执行刷盘动作之间存在 一个短暂却会产生问题的时间窗。通过 publisherconfirm 机制能够确保客户端知道哪些消息己经存入磁盘, 尽管如此,一般不希望遇到因单点故障导致的服务不可用。 引入镜像队列(Mirror Queue)的机制,可以将队列镜像到集群中的其他 Broker 节点之上,如果集群中 的一个节点失效了,队列能自动地切换到镜像中的另一个节点上以保证服务的可用性。

1、搭建步骤

1.启动三台集群节点

2.随便找一个节点添加 policy

在这里插入图片描述

在这里插入图片描述

3.在 node1 上创建一个队列发送一条消息,队列存在镜像队列

在这里插入图片描述

创建的镜像队列:+1

在这里插入图片描述

始终保持有两份主备

在这里插入图片描述

在这里插入图片描述

4.停掉 node1 之后发现 node2 成为镜像队列

在这里插入图片描述

在这里插入图片描述

会将node1中的消息备份到node2和node3中,保持有两份

测试效果:

在这里插入图片描述

在这里插入图片描述

5.就算整个集群只剩下一台机器了 依然能消费队列里面的消息 说明队列里面的消息被镜像队列传递到相应机器里面了 ,消息并未丢失

24、Haproxy+Keepalive 实现高可用负载均衡

1、整体架构图

在这里插入图片描述

2、Haproxy 实现负载均衡

​ HAProxy 提供高可用性、负载均衡及基于 TCPHTTP 应用的代理,支持虚拟主机,它是免费、快速并 且可靠的一种解决方案,包括 Twitter,Reddit,StackOverflow,GitHub 在内的多家知名互联网公司在使用。 HAProxy 实现了一种事件驱动、单一进程模型,此模型支持非常大的井发连接数

​ 扩展 nginx,lvs,haproxy 之间的区别: http://www.ha97.com/5646.html

搭建步骤

1.下载 haproxy(在 node1 和 node2)

 yum -y install haproxy 

2.修改 node1 和 node2 的 haproxy.cfg

 vim /etc/haproxy/haproxy.cfg 

需要修改红色 IP 为当前机器 IP

在这里插入图片描述

3.在两台节点启动 haproxy

haproxy -f /etc/haproxy/haproxy.cfg 
ps -ef | grep haproxy  

4.访问地址

http://红圈中修改后的IP:8888/stats

3、Keepalived 实现双机(主备)热备

​ 试想如果前面配置的 HAProxy 主机突然宕机或者网卡失效,那么虽然 RbbitMQ 集群没有任何故障但是 对于外界的客户端来说所有的连接都会被断开结果将是灾难性的为了确保负载均衡服务的可靠性同样显得 十分重要,这里就要引入 Keepalived 它能够通过自身健康检查、资源接管功能做高可用(双机热备),实现 故障转移.

搭建步骤

1.下载 keepalived

yum -y install keepalived 

2.节点 node1 配置文件

 vim /etc/keepalived/keepalived.conf 

把资料里面的 keepalived.conf 修改之后替换

3.节点 node2 配置文件

需要修改 global_defs 的 router_id,如:nodeB

其次要修改 vrrp_instance_VI 中 state 为"BACKUP";

最后要将 priority 设置为小于 100 的值

4.添加 haproxy_chk.sh

(为了防止 HAProxy 服务挂掉之后 Keepalived 还在正常工作而没有切换到 Backup 上,所以 这里需要编写一个脚本来检测 HAProxy 务的状态,当 HAProxy 服务挂掉之后该脚本会自动重启 HAProxy 的服务如果不成功则关闭 Keepalived 服务,这样便可以切换到 Backup 继续工作)

 vim /etc/keepalived/haproxy_chk.sh(可以直接上传文件) 
 修改权限 
 chmod 777 /etc/keepalived/haproxy_chk.sh  

5.启动 keepalive 命令(node1 和 node2 启动)

systemctl start keepalived 

6.观察 Keepalived 的日志

tail -f /var/log/messages -n 200 

7.观察最新添加的 vip

ip add show 

8.node1 模拟 keepalived 关闭状态

systemctl stop keepalived  

9.使用 vip 地址来访问 rabbitmq 集群

RabbitMQ-消息队列:镜像队列、Haproxy+Keepalive 实现高可用负载均衡 到此完结,笔者归纳、创作不易,大佬们给个3连再起飞吧

  • 33
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小孔靠得住

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值