前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >RabbitMQ之集群搭建

RabbitMQ之集群搭建

作者头像
别团等shy哥发育
发布2023-02-25 14:29:44
发布2023-02-25 14:29:44
45600
代码可运行
举报
运行总次数:0
代码可运行

`RabbitMQ之集群搭建`

RabbitMQ集群

1、Clustering

1.1 使用集群的原因

  最开始我们介绍了如何安装及运行 RabbitMQ 服务,不过这些是单机版的,无法满足目前真实应用的 要求。如果 RabbitMQ 服务器遇到内存崩溃、机器掉电或者主板故障等情况,该怎么办?单台 RabbitMQ 服务器可以满足每秒 1000 条消息的吞吐量,那么如果应用需要 RabbitMQ 服务满足每秒 10 万条消息的吞 吐量呢?购买昂贵的服务器来增强单机 RabbitMQ 务的性能显得捉襟见肘,搭建一个 RabbitMQ 集群才是 解决实际问题的关键.

1.2 集群搭建步骤

架构图如下:

1.2.1 准备三台虚拟机

可以给其中一台机器配置好环境,然后直接克隆两台就行。

1.2.2 修改三台机器的主机名称

代码语言:javascript
代码运行次数:0
运行
复制
vim /etc/hostname
代码语言:javascript
代码运行次数:0
运行
复制
node1     192.168.159.33 
node2     192.168.159.34 
node3     192.168.159.35 

1.2.3 配置各个节点的hosts文件,让各个节点都能户向识别对方

1.2.4 确保各个节点的cookie文件使用的是同一个值

在node1节点的机器上执行远程操作命令

代码语言:javascript
代码运行次数:0
运行
复制
scp /var/lib/rabbitmq/.erlang.cookie root@node2:/var/lib/rabbitmq/.erlang.cookie
代码语言:javascript
代码运行次数:0
运行
复制
scp /var/lib/rabbitmq/.erlang.cookie root@node3:/var/lib/rabbitmq/.erlang.cookie

1.2.5 启动RabbitMQ服务

顺带启动Erlang虚拟机和RabbitMQ应用服务(在三台节点上分别执行以下命令)

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmq-server -detached

1.2.6 在节点2执行如下命令

(rabbitmqctl stop 会将 Erlang 虚拟机关闭,rabbitmqctl stop_app 只关闭 RabbitMQ 服务)

代码语言:javascript
代码运行次数:0
运行
复制
abbitmqctl stop_app
代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl reset

将节点2加入到节点1所在的集群中

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl join_cluster rabbit@node1

只启动应用服务

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl start_app

1.2.7 在节点3执行如下命令

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl stop_app
代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl reset
代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl join_cluster rabbit@node2
代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl start_app

1.2.8 查看集群状态

随便在一台机器上面执行如下命令:

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl cluster_status

1.2.9 需要重新设置设置用户

下面这些命令在三台节点都要执行

创建账号:

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl add_user admin 123

设置用户角色

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl set_user_tags admin administrator

设置用户权限

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl set_permissions -p "/" admin ".*" ".*" ".*"

1.2.10 查看管理界面

随便进入某一台节点的管理界面

没有任何问题,集群搭建成功

2、镜像队列

2.1 使用镜像队列的原因

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

  引入镜像队列(Mirror Queue)的机制,可以将队列镜像到集群中的其他 Broker 节点之上,如果集群中 的一个节点失效了,队列能自动地切换到镜像中的另一个节点上以保证服务的可用性。

2.2 镜像队列搭建步骤

2.2.1 随便找一个节点添加policy

这里我在节点2(192.168.159.34)这台机器上添加

这里pattern那一栏其实就相当于是一个正则表达式,

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

2.2.2 停掉node1节点的机器,node2成为镜像队列

停掉node1

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl stop_app

可以看到,node1节点宕机之后,node2成为镜像队列

2.2.3 测试一台机器宕机之后,消息是否还能被消费。

开始消费node2节点中队列的消息,发现依然可以被消费。

  就算整个集群只剩下一台机器了,依然能够消费队列里面的消息,说明队列里面的消息被镜像队列传递到响应的机器里面了。

3、解除集群节点的命令

根据上面搭建的集群,在node2和node3节点上执行如下命令

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl stop_app
rabbitmqctl reset
rabbitmqctl start_app
rabbitmqctl cluster_status

(node1 机器上执行下列命令)

代码语言:javascript
代码运行次数:0
运行
复制
rabbitmqctl forget_cluster_node rabbit@node2
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • `RabbitMQ之集群搭建`
  • RabbitMQ集群
  • 1、Clustering
    • 1.1 使用集群的原因
    • 1.2 集群搭建步骤
      • 1.2.1 准备三台虚拟机
      • 1.2.2 修改三台机器的主机名称
      • 1.2.3 配置各个节点的hosts文件,让各个节点都能户向识别对方
      • 1.2.4 确保各个节点的cookie文件使用的是同一个值
      • 1.2.5 启动RabbitMQ服务
      • 1.2.6 在节点2执行如下命令
      • 1.2.7 在节点3执行如下命令
      • 1.2.8 查看集群状态
      • 1.2.9 需要重新设置设置用户
      • 1.2.10 查看管理界面
  • 2、镜像队列
    • 2.1 使用镜像队列的原因
    • 2.2 镜像队列搭建步骤
      • 2.2.1 随便找一个节点添加policy
      • 2.2.2 在node1上创建一个队列发送消息,队列存在镜像队列
      • 2.2.2 停掉node1节点的机器,node2成为镜像队列
      • 2.2.3 测试一台机器宕机之后,消息是否还能被消费。
  • 3、解除集群节点的命令
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档