如何保证rabbitmq高可用?

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

1.普通集群模式

在多台机器上启动多个rabbitmq实例,每个机器启动一个。但是创建的queue,只会放在一个rabbtimq实例上,但是每个实例都同步queue的元数据。完了你消费的时候,实际上如果连接到了另外一个实例,那么那个实例会从queue所在实例上拉取数据过来。

如何保证rabbitmq高可用?_第1张图片

这种方式确实很麻烦,也不怎么好,没做到所谓的分布式,就是个普通集群。

因为这导致要么消费者每次随机连接一个实例然后拉取数据,要么固定连接那个queue所在实例消费数据,前者有数据拉取的开销,后者导致单实例性能瓶颈。

而且如果那个放queue的实例宕机了,会导致接下来其他实例就无法从那个实例拉取,如果开启了消息持久化,让rabbitmq落地存储消息的话,消息不一定会丢,得等这个实例恢复了,然后才可以继续从这个queue拉取数据。

这种方案没有什么所谓的高可用性,主要是提高吞吐量的,就是说让集群中多个节点来服务某个queue的读写操作。

2.镜像集群模式

如何保证rabbitmq高可用?_第2张图片

这种模式,才是所谓的rabbitmq的高可用模式,跟普通集群模式不一样的是,创建的queue,无论元数据还是queue里的消息都会存在于多个实例上,然后每次写消息到queue的时候,都会自动把消息到多个实例的queue里进行消息同步。

这样的话,好处在于,你任何一个机器宕机了,没事儿,别的机器都可以用。坏处在于,第一,这个性能开销也太大了吧,消息同步所有机器,导致网络带宽压力和消耗很重!第二,这么玩儿,就没有扩展性可言了,如果某个queue负载很重,你加机器,新增的机器也包含了这个queue的所有数据,并没有办法线性扩展你的queue

怎么开启这个镜像集群模式呢?rabbitmq有很好的管理控制台,就是在后台新增一个策略,这个策略是镜像集群模式的策略,指定的时候可以要求数据同步到所有节点的,也可以要求就同步到指定数量的节点,然后再次创建queue的时候,应用这个策略,就会自动将数据同步到其他的节点上去了。

转载于:https://my.oschina.net/hensemlee/blog/3018994

你可能感兴趣的:(如何保证rabbitmq高可用?)