Rabbitmq集群安装与配置

一、rabbitmq安装环境准备

1、安装环境准备

这里,我们以两个节点为例进行安装,一个节点为内存节点,另一个节点为硬盘节点,具体可根据自己需要分配节点。

安装系统

主机名称

IP地址

备注

Cnetos6.8

Server1

10.0.0.13

内存节点

Centos6.8

Server2

10.0.0.14

硬盘节点

2、修改两台节点主机hosts文件使之能互相解析

在两台主机的hosts文件中分别执行如下操作:

]#cat >> /etc/hosts <<EOF

> 10.0.0.13 server1

> 10.0.0.14 server2

> EOF

二、rabbitmq的安装(两台节点上需要安装同样的软件)

1、安装所需软件

(1)安装socat

]#wget http://dl.fedoraproject.org/pub/epel/6/x86_64//socat-1.7.2.3-1.el6.x86_64.rpm

]#yum localinstall -y socat-1.7.2.3-1.el6.x86_64.rpm

(2)安装erlang19.0.4

]#wget  http://www.rabbitmq.com/releases/erlang/erlang-19.0.4-1.el6.x86_64.rpm

]#yum localinstall -y erlang-19.0.4-1.el6.x86_64.rpm

(3)安装rabbitmq-server

]#wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.2/rabbitmq-server-3.6.2-1.noarch.rpm

]#yum localinstall -y erlang-19.0.4-1.el6.x86_64.rpm

2、配置启动rabbitmq

(1)启动rabbitmq

 ~]# service rabbitmq-server start    #启动rabbitmq

 ~]# service rabbitmq-server status   #查看rabbitmq的运行状态

(2)开启扩展管理,开启后可以通过网页登录管理rabbitmq,登录地址为服务器加端口号15672

~]# rabbitmq-plugins enable rabbitmq_management

~]# ss -tanl | grep 5672   #开启扩展管理后,才能看到端口号15672,有时看不到,需要重启rabbitmq

LISTEN     0      128                       :::5672                   ::*     

LISTEN     0      128                       *:25672                  *:*     

LISTEN     0      128                       *:15672                  *:*     

三、rabbitmq集群配置

1、在配置集群前需要同步elrang cookie

将一台节点的elrang cookie同步到其他机器节点(有些版本的elrang cookie存放位置为/var/lib/rabbitmq/..erlang.cookie,有些版本的erlang cookie存放位置为~/..erlang.cookie)。

以下操作均需要在需要同步的机器上操作,有多个节点时需要在其他节点上执行相同的操作,此处我们将10.0.0.13的elrang cookie同步到其他节点。

~]# rabbitmqctl stop   #在同步前停止rabbitmq

~]# scp root@10.0.0.13:/var/lib/rabbitmq/.erlang.cookie /var/lib/rabbitmq/.erlang.cookie

~]# rabbitmqctl start  #在同步后启动rabbitmq

2、创建rabbitmq集群

~]#rabbitmqctl stop_app

~]#rabbitmqctl reset

~]#rabbitmqctl join_cluster rabbit@n1  #默认创建的为磁盘节点,如果创建内存节点需要在此命令后面加--ram,rabbitmq中至少需要一个磁盘节点

~]#rabbitmqctl start_app

3、验证集群

Rabbitmq集群创建完成后可通过命令“ rabbitmqctl cluster_status”来验证集群,如出现如下信息则说明rabbitmq集群创建成功。

 ~]# rabbitmqctl cluster_status

 Cluster status of node rabbit@server1 ...

[{nodes,[{disc,[rabbit@server1,rabbit@server2]}]},

 {running_nodes,[rabbit@server2,rabbit@server1]},

 {cluster_name,<<"rabbit@server1">>},

 {partitions,[]},

 {alarms,[{rabbit@server2,[]},{rabbit@server1,[]}]}]

4、为Rabbitmq添加用户

由于为rabbitmq做了集群,所以在一台设备上的操作,会同步到其他节点,所以添加用户只需在一台节点上添加,会同步到其他节点。

 ~]# rabbitmqctl  add_user username password   #为rabbitmq添加用户并设置密码

 ~]# rabbitmqctl set_user_tags username administrator  #为创建的用户添加标签,即将用户加入到某个组中

Rabbitmq集群安装配置的更多相关文章

  1. RabbitMQ集群安装配置+HAproxy+Keepalived高可用

    RabbitMQ集群安装配置+HAproxy+Keepalived高可用 转自:https://www.linuxidc.com/Linux/2016-10/136492.htm rabbitmq 集 ...

  2. kubernetes rabbitmq 集群安装配置

    生成secret来保存relang-cookie: secret.yml文件: apiVersion: v1kind: Secretmetadata: name: rabbit-cookietype: ...

  3. 1.rabbitmq 集群安装及负载均衡设置

    标题 : 1.rabbitmq 集群安装及负载均衡设置 目录 : RabbitMQ 序号 : 1 vim /etc/pam.d/login #对于64位系统,在文件中添加如下行 session req ...

  4. CentOS下Hadoop-2.2.0集群安装配置

    对于一个刚开始学习Spark的人来说,当然首先需要把环境搭建好,再跑几个例子,目前比较流行的部署是Spark On Yarn,作为新手,我觉得有必要走一遍Hadoop的集群安装配置,而不仅仅停留在本地 ...

  5. hbase单机环境的搭建和完全分布式Hbase集群安装配置

    HBase 是一个开源的非关系(NoSQL)的可伸缩性分布式数据库.它是面向列的,并适合于存储超大型松散数据.HBase适合于实时,随机对Big数据进行读写操作的业务环境. @hbase单机环境的搭建 ...

  6. hive集群安装配置

    hive 是JAVA写的的一个数据仓库,依赖hadoop.没有安装hadoop的,请参考http://blog.csdn.net/lovemelovemycode/article/details/91 ...

  7. 集群安装配置Hadoop具体图解

    集群安装配置Hadoop 集群节点:node4.node5.node6.node7.node8. 详细架构: node4 Namenode,secondnamenode,jobtracker node ...

  8. spark集群安装配置

    spark集群安装配置 一. Spark简介 Spark是一个通用的并行计算框架,由UCBerkeley的AMP实验室开发.Spark基于map reduce 算法模式实现的分布式计算,拥有Hadoo ...

  9. 原创:centos7.1下 ZooKeeper 集群安装配置+Python实战范例

    centos7.1下 ZooKeeper 集群安装配置+Python实战范例 下载:http://apache.fayea.com/zookeeper/zookeeper-3.4.9/zookeepe ...

随机推荐

  1. 使用VS Code开发调试.NET Core 2.0

    使用VS Code 从零开始开发调试.NET Core 2.0.无需安装VS 2017 15.3+即可开发调试.NET Core 2.0应用. VS Code 全称是 Visual Studio Co ...

  2. volatile可见性的一些认识

    一.前言 volatile的关键词的使用在JVM内存模型中已是老生常谈了,这篇文章主要结合自己对可见性的一些认识和一些直观的例子来谈谈volatile.文章正文大致分为三部分,首先会介绍一下happe ...

  3. 微信小程序源码推荐

    wx-gesture-lock  微信小程序的手势密码 WXCustomSwitch 微信小程序自定义 Switch 组件模板 WeixinAppBdNovel 微信小程序demo:百度小说搜索 sh ...

  4. C语言指针(三)指针传递给函数

    实例1:传递一个无符号的long型指针给该函数 #include<stdio.h>#include<time.h>void getSeconds(unsignedlong*pa ...

  5. SpringMVC详解(五)------参数绑定

    参数绑定,简单来说就是客户端发送请求,而请求中包含一些数据,那么这些数据怎么到达 Controller ?这在实际项目开发中也是用到的最多的,那么 SpringMVC 的参数绑定是怎么实现的呢?下面我 ...

  6. java异常之后代码执行测试

    1.程序代码: public static void main(String[] args) { int[] a = {1,2,3}; for(int i=0;i<4;i++){ System. ...

  7. "R6002 floating point support not loaded"问题分析

    今天为了追踪程序线程退出耗时时间,添加了耗时时间输出日志: TimerMeter tm; // do some threads exit logic float fSecs = tm.Elapsed( ...

  8. TIKV副本一致性检查机制分析

    背景 TIKV使用raft协议来实现副本同步,任何时刻写入一个KEY-VAL键值对,都会基于RAFT协议复制到不同机器的三个副本上,raft协议本身能保证副本同步的强一致性,但是任何系统都可能存在BU ...

  9. Java中的注释-快捷键

    Eclipse中的快捷键  单行注释   Ctrl+/ 多行注释    Ctrl+Shift+/  文档注释    Shift +Alt+j /** * @author Lenovo * 文档注释 * ...

  10. 更改pip源至国内镜像,显著提升下载速度

    经常在使用Python的时候需要安装各种模块,而pip是很强大的模块安装工具,但是由于国外官方pypi经常被墙,导致不可用,所以我们最好是将自己使用的pip源更换一下,这样就能解决被墙导致的装不上库的 ...