zoukankan      html  css  js  c++  java
  • rabiitmq集群完整安装

    通过 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
     
  • 相关阅读:
    bzoj 1176 cdq分治套树状数组
    Codeforces 669E cdq分治
    Codeforces 1101D 点分治
    Codeforces 1100E 拓扑排序
    Codeforces 1188D Make Equal DP
    Codeforces 1188A 构造
    Codeforces 1188B 式子转化
    Codeforces 1188C DP 鸽巢原理
    Codeforces 1179D 树形DP 斜率优化
    git commit -m "XX"报错 pre -commit hook failed (add --no-verify to bypass)问题
  • 原文地址:https://www.cnblogs.com/rongfengliang/p/6202403.html
Copyright © 2011-2022 走看看