RabbitMQ 构建高可靠集群架构

主备模式和主从模式的区别?

主备模式:主节点读写,从节点读写都不可,作为备胎,启动切换,主备相互转换,主节点可能变成从节点,从节点有一天会变成主节点,有点备胎的意思。一主多备。

主从模式:主节点读写, 从节点只读。

RabbitMQ 构建高可靠集群架构

  1. RabbitMQ集群架构模式

主备模式:实现RabbitMQ的高可用集群,一般在并发和数据量不高的情况下,这种模型非常的好用且简单。主备模式也称作Warren模式。

主备模式:所谓rabbitmq 另外一种模式就是warren(兔子窝),就是一个主/备方案(主节点如果挂了,从节点提供服务而已,和activemq利用zookeeper做主/备一样)
RabbitMQ 构建高可靠集群架构_第1张图片
主备模式:

HaProxy配置:
listen rabbitmq_cluster
bind 0.0.0.0:5672
mode tcp #配置TCP模式
balance roundrobin #简单的轮询
server bhz76 192.168.11.76:5672 check inter 5000 rise 2 fall 2 #主节点
server bhz77 192.168.11.77:5672 bakup check inter 5000 rise 2 fall 2 #备用节点
备注: rabbitmq集群节点配置
#inter 每隔五秒对mq集群做健康检查,2次正确证明服务器可用,2
次失败证明服务器不可用,并且配置主备机制。

远程模式:远程模式可以实现双活的一种模式,简称Shovel模式,所谓Shovel就是我们可以把消息进行不同数据中心的复制工程,我们可以跨地域的让两个MQ集群互联。远距离通信和复制。

Shovel的架构模型

RabbitMQ 构建高可靠集群架构_第2张图片
Shovel order processing tepology
RabbitMQ 构建高可靠集群架构_第3张图片
Shovel集群的配置,首先启动rabbitmq插件,命令如下:

  1. rabbitmq-plugins enable amqp_client
  2. rabbitmq-plugins enable rabbitmq_shovel
  3. 创建rabbitmq.config 文件 : touch /etc/rabbitmq/rabbitmq.config
  4. 添加配置见rabbitmq.config
  5. 最后我们需要源服务器和目的地服务器都使用相同的配置文件(rabbitmq.config)

镜像模式:保证100%数据不丢失,在实际工作中也是用的最多的,并且实现集群非常的简单,一般互联网大厂都会构建这种镜像进群模式。

Mirror镜像队列,目的是为了保证rabbitmq数据的高可靠性解决方案,主要就是实现数据的同步,一般来讲是2-3个节点实现数据同步(对于100%数据可靠性解决方案,一般是3个节点)

集群架构如下:

  1. 集群的配置文件与集群运维故障,失败转移

  2. 高级插件的使用

你可能感兴趣的:(消息队列)