首页 技术 正文
技术 2022年11月19日
0 收藏 634 点赞 3,660 浏览 1771 个字

通过 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 node1192.168.1.2 node2192.168.1.3 node3

 3. 设置 Erlang CookieErlang 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@node1node2 # rabbitmqctl start_app  node3 # rabbitmqctl stop_app node3 # rabbitmqctl join_cluster rabbit@node1node3 # 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 tcpbalance 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 3server   node2 192.168.1.3:5672 check inter 2000 rise 2 fall 3 
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,497
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,910
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,744
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,497
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,135
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,298