前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >RabbitMQ如何实现高可用

RabbitMQ如何实现高可用

作者头像
Java学习录
发布2019-07-10 18:39:32
9700
发布2019-07-10 18:39:32
举报
文章被收录于专栏:Java学习录Java学习录

RabbitMQ一共具有三种模式:单机、普通集群、镜像集群

单机模式

单机模式,就是我们平常玩的demo,生产上肯定不能用。

普通集群

普通集群就是在多台机器上启动多个实例。每个队列只会存在其中的一个实例上,然后所有实例同步这些队列的元数据。消费者在进行消费的时候,如果连接的实例上恰好不是队列所在的实例,就会根据队列的元数据去队列所在实例上拉取数据

由此可知,集群模式并没做到分布式,如果队列所在的实例宕机了,会导致接下来其他实例就无法从那个实例拉取消息

所以集群主要是提高吞吐量的

镜像集群

跟普通集群模式不一样的是,在镜像集群模式下,无论队列中的元数据还是消息都会存在于多个实例上,就是说,每个 RabbitMQ 节点都有这个 队列的一个完整镜像。然后每次写消息到队列的时候,都会自动把消息同步到多个实例上

如何开启镜像集群

首先镜像集群是在普通集群的基础上的,所以你要先搭建一个普通集群,然后在随意一个实例上执行如下命令创建一个策略即可开启

代码语言:javascript
复制
rabbitmqctl set_policy -p vhostName name  "^xxqueue" '{"ha-mode":"all"}'
  • name是策略的名字
  • xxqueue是需要匹配的队列名称,如果要匹配所有的话使用^
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-06-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Java学习录 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档