RabbitMQ 集群与高可用配置

集群概述

通过 Erlang 的分布式特性(通过 magic cookie 认证节点)进行 RabbitMQ 集群,各 RabbitMQ 服务为对等节点,即每个节点都提供服务给客户端连接,进行消息发送与接收。
 
这些节点通过  RabbitMQ HA 队列(镜像队列)进行消息队列结构复制。本方案中搭建 3 个节点,并且都是磁盘节点(所有节点状态保持一致,节点完全对等),只要有任何一个节点能够工作,RabbitMQ 集群对外就能提供服务。

环境

  • CentOS 6.4,64位
  • RabbitMQ 3.1.5
  • HAProxy 1.4.22
 
RabbitMQ 集群安装在 3 个节点上:192.168.1.1、192.168.1.2、192.168.1.3;
HAProxy 安装在 192.168.1.4 上,用于对外提供 RabbitMQ 均衡。
 
所需安装包  下载

配置步骤

1. 安装 erlang、rabbitmq
在 192.168.1.1、192.168.1.2、192.168.1.3 三个节点上安装,然后开启 RabbitMQ 监控插件:
rabbitmq-plugins enable rabbitmq_management
2. 修改 /etc/hosts
加入集群 3 个节点的描述:
192.168.1.1 node1
192.168.1.2 node2
192.168.1.3 node3
 
3. 设置 Erlang Cookie
Erlang Cookie 文件:/var/lib/rabbitmq/.erlang.cookie。这里将 node1 的该文件复制到 node2、node3,由于这个文件权限是 400,所以需要先修改 node2、node3 中的该文件权限为 777:
# chmod 777 /var/lib/rabbitmq/.erlang.cookie
然后将 node1 中的该文件拷贝到 node2、node3,最后将权限和所属用户/组修改回来:
# chmod 400 /var/lib/rabbitmq/.erlang.cookie
# chown rabbitmq /var/lib/rabbitmq/.erlang.cookie
# chgrp rabbitmq /var/lib/rabbitmq/.erlang.cookie
 
4. 使用 -detached 参数运行各节点
# rabbitmqctl stop
# rabbitmq-server -detached
 
5. 组成集群
将 node2、node3 与 node1 组成集群:
 
node2 # rabbitmqctl stop_app
node2 # rabbitmqctl join_cluster rabbit@node1
node2 # rabbitmqctl start_app
  
node3 # rabbitmqctl stop_app
node3 # rabbitmqctl join_cluster rabbit@node1
node3 # rabbitmqctl start_app
 
此时 node2 与 node3 也会自动建立连接;如果要使用内存节点,则可以使用
node2 # rabbitmqctl join_cluster  --ram rabbit@node1 加入集群。
 
集群配置好后,可以在 RabbitMQ 任意节点上执行 rabbitmqctl cluster_status 来查看是否集群配置成功。
 
6. 设置镜像队列策略
在任意一个节点上执行:
# rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'
将所有队列设置为镜像队列,即队列会被复制到各个节点,各个节点状态保持一直。
 
完成这 6 个步骤后,RabbitMQ 高可用集群就已经搭建好了,最后一个步骤就是搭建均衡器。
 
7. 安装并配置 HAProxy
在 192.168.1.4 上安装 HAProxy,然后修改 /etc/haproxy/haproxy.cfg:
 
listen rabbitmq_cluster 0.0.0.0:5672
 
mode tcp
balance roundrobin
 
server   node1 192.168.1.1:5672 check inter 2000 rise 2 fall 3 
server   node2 192.168.1.2:5672 check inter 2000 rise 2 fall 3
server   node2 192.168.1.3:5672 check inter 2000 rise 2 fall 3

---- EOF ----

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在OpenStack中实现RabbitMQ高可用性,需要配置RabbitMQ集群。以下是配置RabbitMQ集群的步骤: 1. 安装RabbitMQ 在所有节点上安装RabbitMQ。可以使用以下命令在Ubuntu上安装: ``` sudo apt-get install rabbitmq-server ``` 2. 配置防火墙 确保RabbitMQ端口在防火墙中开放。默认情况下,RabbitMQ使用5672端口。 3. 创建RabbitMQ用户 在所有节点上创建相同的RabbitMQ用户。可以使用以下命令创建用户: ``` sudo rabbitmqctl add_user <username> <password> ``` 请将<username>和<password>替换为所需的用户名和密码。 4. 授予RabbitMQ用户权限 使用以下命令将管理员角色授予RabbitMQ用户: ``` sudo rabbitmqctl set_user_tags <username> administrator ``` 请将<username>替换为上一步中创建的用户名。 5. 启用RabbitMQ插件 要启用RabbitMQ插件,请使用以下命令: ``` sudo rabbitmq-plugins enable rabbitmq_management ``` 6. 创建RabbitMQ集群 在所有节点上,编辑RabbitMQ配置文件/etc/rabbitmq/rabbitmq.config并添加以下内容: ``` [ {rabbit, [ {cluster_nodes, {['rabbit@node1', 'rabbit@node2'], disc}}, {cluster_partition_handling, autoheal}, {loopback_users, []}, {default_user, <<"guest">>}, {default_pass, <<"guest">>} ]} ]. ``` 请将节点名称替换为您的实际节点名称。 7. 重启RabbitMQ 在所有节点上,使用以下命令重启RabbitMQ: ``` sudo systemctl restart rabbitmq-server ``` 8. 验证RabbitMQ集群 使用以下命令验证RabbitMQ集群是否正常工作: ``` sudo rabbitmqctl cluster_status ``` 如果一切正常,您应该看到类似以下内容的输出: ``` Cluster status of node rabbit@node1 ... [{nodes,[{disc,['rabbit@node1','rabbit@node2']}]}, {running_nodes,['rabbit@node1','rabbit@node2']}, {partitions,[]}] ``` 这表明RabbitMQ集群已成功配置并正在运行。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值