RabbitMQ集群

栏目: Erlang · 发布时间: 7年前

内容简介:RabbitMQ集群

一、前言

线上的 RabbitMQ用的是单节点,前段时间由于机器内存不足,发生了OOM,业务受到了影响,故打算换成 RabbitMQ集群。RabbitMQ模式有三种,分别是:单一模式、普通模式、镜像模式,镜像模式才是RabbitMQ真正的HA方案,关于更详细的简绍,请移步到官网:http://www.rabbitmq.com/ha.html ,下面是关于RabbitMQ集群的部署过程:

二、环境

erlang版本:

erlang-19.0.4-1.el7.centos.x86_64

rabbitmq版本:

rabbitmq-server-3.6.6

服务器主机名:

ip-172-31-13-114  磁盘节点
ip-172-31-15-124 内存节点
ip-172-31-11-216 内存节点

三、安装

1、erlang安装

a、wget https://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm
rpm -Uvh erlang-solutions-1.0-1.noarch.rpm
b、rpm --import https://packages.erlang-solutions.com/rpm/erlang_solutions.asc
c、Add the following lines to some file in /etc/yum.repos.d/:
[erlang-solutions]
name=Centos $releasever - $basearch - Erlang Solutions
baseurl=https://packages.erlang-solutions.com/rpm/centos/$releasever/$basearch
gpgcheck=1
gpgkey=https://packages.erlang-solutions.com/rpm/erlang_solutions.asc
enabled=1
d、yum install erlang esl-erlang

2、RabbitMQ 安装

a、 wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.6/rabbitmq-server-generic-unix-3.6.6.tar.xz
b、tar -xvf rabbitmq-server-generic-unix-3.6.6.tar.xz
c、 mv rabbitmq_server-3.6.6 /data/rabbitmq
d、cd /data/rabbitmq/;./sbin/rabbitmq-server -detached

四、配置

1、需要配置host,不然集群没用办法创建,我这里用的aws的ec2,用的默认主机名,这里就不修改了

2、拷贝.erlang.cookie,RabbitMQ集群依赖erlang集群才能工作,所以需要先构建erlang集群,.erlang.cookie文件在启动用户的家目录下,我这里是用work用户启动的RabbitMQ,拷贝一台服务器的/home/work/.erlang.cookie到其他机器并设置权限

chown work:work  /home/work/.erlang.cookie
chmod 400 /home/work/.erlang.cookie

3、设置集群的模式:镜像

rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'

PS:

在任意一个节点操作即可,这里在ip-172-31-13-114上操作

4、加入集群(ip-172-31-15-124 、ip-172-31-11-216 )

rabbitmqctl stop_app
rabbitmqctl join_cluster --ram rabbit@ip-172-31-13-114
rabbitmqctl start_app

PS:

--ram 指定内存节点类型,--disc指定磁盘节点类型

5、查看集群

rabbitmqctl cluster_status

6、启用管理和监控模块

rabbitmq-plugins enable rabbitmq_management

7、设置集群的名字

rabbitmqctl set_cluster_name my_mq

8、添加用户:

rabbitmqctl add_user spider spider

9、设置用户权限策略

rabbitmqctl set_user_tags spider administrator

10、vhost授权

rabbitmqctl set_permissions -p / spider '.*' '.*' '.*'

11、改变节点类型为磁盘节点

rabbitmqctl stop_app
rabbitmqctl change_cluster_node_type disc
rabbitmqctl start_app

12、将节点移出集群

将节点ip-172-31-11-216 移出集群前,先要stop_app,然后reset节点

[root@ip-172-31-11-216 ~]# rabbitmqctl stop_app
Stopping node rabbit@ip-172-31-11-216 ...
[root@ip-172-31-11-216 ~]# rabbitmqctl reset
Resetting node rabbit@ip-172-31-11-216 ...

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

深入理解计算机系统

深入理解计算机系统

Randal E.Bryant、David O'Hallaron / 龚奕利、雷迎春 / 中国电力出版社 / 2004-5-1 / 85.00元

从程序员的视角,看计算机系统! 本书适用于那些想要写出更快、更可靠程序的程序员。通过掌握程序是如何映射到系统上,以及程序是如何执行的,读者能够更好的理解程序的行为为什么是这样的,以及效率低下是如何造成的。粗略来看,计算机系统包括处理器和存储器硬件、编译器、操作系统和网络互连环境。而通过程序员的视角,读者可以清晰地明白学习计算机系统的内部工作原理会对他们今后作为计算机科学研究者和工程师的工作有......一起来看看 《深入理解计算机系统》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器