zoukankan      html  css  js  c++  java
  • rabbitmq集群搭建

    转  https://blog.csdn.net/a491857321/article/details/52814045

    rabbitmq集群搭建

    集群概述

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

    环境

    • CentOS 7,64位
    • RabbitMQ 3.6.3
    • HAProxy 1.6.0
      RabbitMQ 集群安装在 3 个节点上:192.168.1.1、192.168.1.2、192.168.1.3;HAProxy 安装在 192.168.1.4 上,用于对外提供 RabbitMQ 负载均衡服务。

    配置步骤

    1. 修改 /etc/hosts,并配置ssh相互免密登录

    [root@node1 ~]# vi /etc/hosts
    192.168.1.1 node1
    192.168.1.2 node2
    192.168.1.3 node3

    2. 安装 erlang、rabbitmq
      在 192.168.1.1、192.168.1.2、192.168.1.3 三个节点上安装,然后开启 RabbitMQ 监控插件。

    [root@node1 ~]# wget http://www.rabbitmq.com/releases/erlang/erlang-18.1-1.el7.centos.x86_64.rpm
    [root@node1 ~]# wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.3/rabbitmq-server-3.6.3-1.noarch.rpm
    [root@node1 ~]# rpm -ivh erlang-18.1-1.el7.centos.x86_64.rpm
    [root@node1 ~]# rpm -ivh rabbitmq-server-3.6.3-1.noarch.rpm
    [root@node1 ~]# rabbitmq-plugins enable rabbitmq_management

    3. 设置 Erlang Cookie
      Erlang Cookie 文件:/var/lib/rabbitmq/.erlang.cookie。这里将 node1 的该文件复制到 node2、node3,由于这个文件权限是 400,所以需要先修改 node2、node3 中的该文件权限为 777,然后将 node1 中的该文件拷贝到 node2、node3,最后将权限和所属用户/组修改回来。

    [root@node1 ~]# chmod 777 /var/lib/rabbitmq/.erlang.cookie
    [root@node1 ~]# scp -r /var/lib/rabbitmq/.erlang.cookie root@node2:/var/lib/rabbitmq/.erlang.cookie
    [root@node1 ~]# scp -r /var/lib/rabbitmq/.erlang.cookie root@node3:/var/lib/rabbitmq/.erlang.cookie
    [root@node1 ~]# chmod 400 /var/lib/rabbitmq/.erlang.cookie
    [root@node1 ~]# chown rabbitmq /var/lib/rabbitmq/.erlang.cookie
    [root@node1 ~]# chgrp rabbitmq /var/lib/rabbitmq/.erlang.cookie

    4. 使用 -detached 参数运行各节点

    [root@node1 ~]# rabbitmqctl stop
    [root@node1 ~]#  rabbitmq-server -detached

    5. 组成集群
    将 node2、node3 与 node1 组成集群

    [root@node2 ~]# rabbitmqctl stop_app
    [root@node2 ~]# rabbitmqctl join_cluster rabbit@node1
    [root@node2 ~]# rabbitmqctl start_app
    #---------------------------------------------------------------------------------#
    [root@node3 ~]# rabbitmqctl stop_app
    [root@node3 ~]# rabbitmqctl join_cluster rabbit@node1
    [root@node3 ~]# rabbitmqctl start_app

      此时 node2 与 node3 也会自动建立连接;如果要使用内存节点,则可以使用下面的命令加入集群。

    [root@node2 ~]# rabbitmqctl join_cluster *--ram* rabbit@node1

      集群配置好后,可以在 RabbitMQ 任意节点上执行下面的命令来查看是否集群配置成功。

    rabbitmqctl cluster_status

    6. 设置镜像队列策略
      在任意一个节点上执行下面的命令

    [root@node1 ~]# rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'

      将所有队列设置为镜像队列,即队列会被复制到各个节点,各个节点状态保持一直。完成这 6 个步骤后,RabbitMQ 高可用集群就已经搭建好了,最后一个步骤就是搭建均衡器。

    提示:
      RabbitMQ的配置文件为:/etc/rabbitmq/rabbitmq.config
      RabbitMQ的环境配置文件为:/etc/rabbitmq/rabbitmq-env.conf

    7. 安装并配置 HAProxy
      在 192.168.1.4 上安装 HAProxy,然后修改 /etc/haproxy/haproxy.cfg。

    [root@snails ~]# haproxy -vv
    [root@snails ~]# vi /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
    
    listen private_monitoring :8100
           mode    http
           option  httplog
           stats   enable
           #设置haproxy监控地址为http://localhost:8100/rabbitmq-stats 
           stats   uri  /rabbitmq-stats
           stats   refresh 5s
    [root@snails ~]# /usr/sbin/haproxy -D -f /etc/haproxy/haproxy.cfg -p /var/run/haproxy.pid
  • 相关阅读:
    flask 跨域问题
    pip 命令参数说明
    关于ASP.NET动态加载控件的几点实用总结
    记录代码运行耗时的写法
    DevExpress AspxGridView数据绑定
    发现一个Membership的bug
    asp.net页面中文件下载的2种方式
    【部分转】innerText 跟 innerHTML区别
    gridview 的添加删除等技巧 全部按名称取值
    关于Linq to DataTable not in的写法
  • 原文地址:https://www.cnblogs.com/fyy-hhzzj/p/8994954.html
Copyright © 2011-2022 走看看