实验环境:

操作系统为 Centos 7.2

IP hostName

192.168.190.132 node132

192.168.190.139 node139

192.168.190.140 node140

 
 

RabbitMQ相关端口

 
 

  • 4369 (epmd)
  • 5672, 5671 (AMQP 0-9-1 and 1.0 without and with TLS)
  • 25672. This port used by Erlang distribution for inter-node and CLI tools communication and is allocated from a dynamic range (limited to a single port by default, computed as AMQP port + 20000). Seenetworking guide for details.
  • 15672 (if management plugin is enabled)
  • 61613, 61614 (if STOMP is enabled)
  • 1883, 8883 (if MQTT is enabled)

     
     

    相应端口开启防火墙设置

     
     

     
     

    添加EPEL源

     
     

    [root@node139 ~]# rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

    Retrieving https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

    warning: /var/tmp/rpm-tmp.2hDPSr: Header V3 RSA/SHA256 Signature, key ID 352c64e5: NOKEY

    Preparing... ################################# [100%]

    Updating / installing...

    1:epel-release-7-8 ################################# [100%]

     
     

    添加Erlang源

     
     

    [root@node139 ~]# rpm -Uvh http://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm

    Retrieving http://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm

    Preparing... ################################# [100%]

    Updating / installing...

    1:erlang-solutions-1.0-1 ################################# [100%]

    --2016-11-29 06:34:38-- http://packages.erlang-solutions.com/rpm/centos/erlang_solutions.repo

    Resolving packages.erlang-solutions.com (packages.erlang-solutions.com)... 31.172.186.53

    Connecting to packages.erlang-solutions.com (packages.erlang-solutions.com)|31.172.186.53|:80... connected.

    HTTP request sent, awaiting response... 200 OK

    Length: 245

    Saving to: 'erlang_solutions.repo'

     
     

    100%[==========================================================================>] 245 --.-K/s in 0s

     
     

    2016-11-29 06:34:39 (27.5 MB/s) - 'erlang_solutions.repo' saved [245/245]

     
     

    安装RabbitMQ

    软件版本:http://www.rabbitmq.com/releases/rabbitmq-server

     
     

    [root@node139 ~]# wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.6/rabbitmq-server-3.6.6-1.el7.noarch.rpm

    [root@node139 ~]# rpm --import https://www.rabbitmq.com/rabbitmq-signing-key-public.asc

    [root@node139 ~]# yum install rabbitmq-server-3.6.6-1.el7.noarch.rpm

     
     

    启动服务

    [root@node139 ~]# systemctl enable rabbitmq-server.service

    [root@node139 ~]# systemctl start rabbitmq-server.service

     
     

    启用RabbitMQ监控插件

    [root@node139 ~]# rabbitmq-plugins enable rabbitmq_management

    The following plugins have been enabled:

    mochiweb

    webmachine

    rabbitmq_web_dispatch

    amqp_client

    rabbitmq_management_agent

    rabbitmq_management

     
     

    Applying plugin configuration to rabbit@node139... started 6 plugins.

    [root@node139 ~]# netstat -apn | grep 15672

    tcp 0 0 0.0.0.0:15672 0.0.0.0:* LISTEN 4119/beam.smp

     
     

    RabbitMQ用户管理

     
     

    添加用户(用户名root,密码admin)

    [root@node139 ~]# rabbitmqctl add_user admin admin

     
     

    设置用户角色(设置admin用户为管理员角色)

    [root@node139 ~]# rabbitmqctl set_user_tags admin administrator

    Setting tags for user "admin" to [administrator] ...

     
     

    设置用户权限(设置admin用户配置、写、读的权限)

    [root@node139 ~]# rabbitmqctl set_permissions -p / admin ".*" ".*" ".*"

    Setting permissions for user "admin" in vhost "/" ...

     
     

    删除用户(删除guest用户)

    [root@node139 ~]# rabbitmqctl delete_user guest

     
     

     
     

    RabbitMQ集群配置

    集群配置在单机配置完成的基础上进行

    以下以node140为例,node132需要做同样的操作

    • 添加/etc/hosts条目

    在node132、node139、node140里的/etc/hosts文件中分别添加:

    192.168.190.132 node132
    192.168.190.139 node139
    192.168.190.140 node140

     
     

    • 设置每个节点Cookie

    的权限。所以必须保证各节点cookie保持一致,否则节点之间就无法通信

     
     

    [root@node140 /]# echo -n "AZVOCZYZZBVFLBPTBXU" > /var/lib/rabbitmq/.erlang.cookie

    [root@node140 ~]# chown rabbitmq:root /var/lib/rabbitmq/.erlang.cookie

    [root@node140 /]# chmod 600 /var/lib/rabbitmq/.erlang.cookie

    [root@node140 /]# cat /var/lib/rabbitmq/.erlang.cookie

    AZVOCZYZZBVFLBPTBXU

     
     

    启动服务

    [root@node140 ~]# systemctl start rabbitmq-server.service

    [root@node140 ~]# rabbitmq-server -detached

     
     

    开通防火墙

    [root@node140 ~]# firewall-cmd --permanent --add-port={4369/tcp,25672/tcp}

    success

    [root@node140 ~]# firewall-cmd --reload

    success

     
     

  • 加入集群

    默认是磁盘节点,如果是内存节点的话,需要加--ram参数

     
     

    [root@node140 ~]# rabbitmqctl stop_app

    Stopping node rabbit@node140 ...

    [root@node140 ~]# rabbitmqctl join_cluster rabbit@node139

    Clustering node rabbit@node140 with rabbit@node139 ...

    [root@node140 ~]# rabbitmqctl start_app

    Starting node rabbit@node140 ...

  • 设置镜像策略

     
     

    [root@node140 ~]# rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all","ha-sync-mode":"automatic"}'

    Setting policy "ha-all" for pattern "^" to "{\"ha-mode\":\"all\",\"ha-sync-mode\":\"automatic\"}" with priority "0" …

     
     

    启用RabbitMQ监控插件

    cluster搭建起来后若在web管理工具中rabbitmq_management的Overview的Nodes部分看到"Node statistics not available"的信息,说明在该节点上web管理插件还未启用。

    [root@node140 ~]# rabbitmq-plugins enable rabbitmq_management

     
     

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

    [root@node140 ~]# rabbitmqctl cluster_status

     
     

    其它节点需要做同样的操作

     
     

     
     

    登录站点http://192.168.190.139:15672/

     
     

     
     

     
     

     
     

     
     

    参考网址:http://www.rabbitmq.com/clustering.html

    安装中遇到的问题:

    这个/var/lib/rabbitmq/.erlang.cookie文件需要修改文件所有者和文件的权限为rw,否则rabbitmq服务无法启动;

     
     

     
     

     
     

     
     

     
     

     
     

     
     

     
     

     
     

     
     

     
     

     
     

     
     

     
     

RabbitMq 集群搭建的更多相关文章

  1. RabbitMQ集群搭建和使用

    一.环境准备 1.选择RabbitMQ的版本 http://www.rabbitmq.com/changelog.html 注: 不同版本的Linux选择的RabbitMQ版本也不同,参照 http: ...

  2. centos7 rabbitmq集群搭建+高可用

    环境 [root@node1 ~]# cat /etc/redhat-release CentOS Linux release (Core) [root@node1 ~]# uname -r -.el ...

  3. CentOS 7 下 RabbitMQ 集群搭建

    环境 10.0.0.20 node1 10.0.0.21 node2 10.0.0.22 node3 搭建(在所有节点执行) 添加EPEL源 [root@node1 ~]# rpm -Uvh http ...

  4. rabbitmq集群搭建方法简介(测试机linux centos)【转】

    本文将介绍四台机器搭建rabbitmq集群: rabbitmq IP和主机名(每台机器已安装RabbitMQ 3.5.6, Erlang 18.1) 192.168.87.73 localhost73 ...

  5. rabbitmq集群搭建,镜像队列搭建

    原文地址:https://www.jianshu.com/p/11963564dd3d 教你如何从0开始搭建rabbitmq集群 一.准备工作 1.三台centos虚拟机 2.三台虚拟机都安装了doc ...

  6. RabbitMQ集群搭建

    准备三个节点,系统为CentOS7 Node IP rabbitmq01 172.50.0.64 rabbitmq02 172.50.0.65 rabbitmq03 172.50.0.66 这里把no ...

  7. rabbitmq+haproxy+keepalived实现高可用集群搭建

    项目需要搭建rabbitmq的高可用集群,最近在学习搭建过程,在这里记录下可以跟大家一起互相交流(这里只是记录了学习之后自己的搭建过程,许多原理的东西没有细说). 搭建环境 CentOS7 64位 R ...

  8. RabbitMQ的安装及集群搭建方法

    RabbitMQ安装 1 安装erlang 下载地址:http://www.erlang.org/downloads 博主这里采用的是otp_src_19.1.tar.gz (200MB+) [roo ...

  9. 搭建rabbitmq集群

    查看rabbitmq日志文件 开启web管理工具 [root@controller rabbitmq]# rabbitmq-plugins list [root@controller rabbitmq ...

随机推荐

  1. Eclipse中文语言包安装和设置中文Doc

    1.安装中文语言包 Eclipse所有的扩展功能都是以插件的形式添加上去的,安装插件时有多种形式,下面是比较常用的两种: 直接将插件中的文件复制到Eclipse对于的目录中.优点是安装时很方便,缺点是 ...

  2. DotNet生成随机数的一些方法

    在项目开发中,一般都会使用到“随机数”,但是在DotNet中的随机数并非真正的随机数,可在一些情况下生成重复的数字,现在总结一下在项目中生成随机数的方法. 1.随机布尔值: /// <summa ...

  3. 利用WCF双工模式实现即时通讯

    概述 WCF陆陆续续也用过多次,但每次都是浅尝辄止,以将够解决问题为王道,这几天稍闲,特寻了些资料看,昨晚尝试使用WCF的双工模式实现了一个简单的即时通讯程序,通过服务端转发实现客户端之间的通讯.这只 ...

  4. Asp.Net Core 项目实战之权限管理系统(6) 功能管理

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  5. xcode7.1新建项目等问题

    一.LaunchImage不显示 解决办法: 1.在Assets.xcassets新建LaunchImage并加入不同屏幕的launchImage 2.点击项目名,点击TARGETS,选择Genera ...

  6. 执行插入语句,object val = cmd.ExecuteScalar() val = null

    在写接口的过程中遇到错误:空对象不能转换为值类型 因为我们使用的是petapoco,经过调试后发现是 object val = cmd.ExecuteScalar() 这一句造成的报错, val = ...

  7. 【WPF】ChartControl的使用

    一.前言       本月正好做一些关于工程4D,5D的界面展示,正好要用到Dev控件中的ChartControl控件,也就是图表控件. 折腾了两星期完成了一个比较能说的过去的界面吧.(领导要求高,可 ...

  8. C#WebBrowrse拦截下载对话框

    为了实现这个功能,可算是折腾不少时间,网上搜素出来的结果基本都是如何屏蔽警告对话框.后来请教一个技术大牛(程序员之窗的主要作者Starts_2000),他用C++实现了,他尝试了下C#也没有解决,就忙 ...

  9. ASP.NET Core模块概述

    原文地址:ASP.NET Core Module overview By Tom Dykstra, Rick Strahl, and Chris Ross ASP.NET Core模块(ANCM)让你 ...

  10. 微信小程序开发教程

    9月21日晚发布的微信公众平台·小程序内侧邀请,微信应用号(小程序,「应用号」的新称呼)终于来了!目前还处于内测阶段,微信只邀请了部分企业参与封测.想必大家都关心应用号的最终形态到底是什么样子? 怎样 ...