1. 部署Erlang

1.1 RabbitMQ依赖于Erlang,版本对应请查看

https://www.rabbitmq.com/which-erlang.html

1.2 下载安装Erlang

# 添加epel扩展源
yum install epel-release # 先删除可能存在的erlang(非必须)
yum list erlang
yum remove erl* # 清空和更新安装源(非必须)
yum clean
yum update # 参考 https://github.com/rabbitmq/erlang-rpm -> Erlang 21.x -> o use Erlang 21.x on CentOS 6
# 配置安装源
vim /etc/yum.repos.d/rabbitmq-erlang.repo [rabbitmq-erlang]
name=rabbitmq-erlang
baseurl=https://dl.bintray.com/rabbitmq-erlang/rpm/erlang/21/el/6
gpgcheck=1
gpgkey=https://dl.bintray.com/rabbitmq/Keys/rabbitmq-release-signing-key.asc
repo_gpgcheck=0
enabled=0 # 安装
yum install erlang
# 如果出现https://dl.bintray.com/rabbitmq-erlang/rpm/erlang/21/el/6/repodata/repomd.xml: [Errno 14] problem making ssl connection 悲伤,仓库过期了
# 到https://github.com/rabbitmq/erlang-rpm/releases下载(电脑龟速,夸克下载飞速)

1.3 测试Erlang

# 查看版本
erl -v # 退出Erlang 注意尾部的 .
halt().

2. 安装RabbitMQ

2.1 下载 npm 安装包:

rabbitmq-server-3.8.0-1.el6.noarch.rpm

2.3 创建rabbitmq目录并上传npm安装包

cd /usr/local
mkdir rabbitmq
chmod 777 -R rabbitmq

2.4 上传安装包至rabbitmq文件夹内

2.5 进入rabbitmq文件夹 下载签名并安装

cd rabbitmq
# 已有安装包时下载签名
rpm --import https://www.rabbitmq.com/rabbitmq-release-signing-key.asc
# 安装
yum install rabbitmq-server-3.8.0-1.el6.noarch.rpm

2.5 启动mq

# 添加开机启动RabbitMQ服务
chkconfig rabbitmq-server on
# 手动启动服务
service rabbitmq-server start

2.6 配置MQ

# 查看当前所有用户
rabbitmqctl list_users # 查看默认guest用户的权限
rabbitmqctl list_user_permissions guest # 由于RabbitMQ默认的账号用户名和密码都是guest。为了安全起见, 先删掉默认用户
rabbitmqctl delete_user guest # 添加新用户
rabbitmqctl add_user username password # 设置用户tag
rabbitmqctl set_user_tags username administrator # 赋予用户默认vhost的全部操作权限
rabbitmqctl set_permissions -p / username ".*" ".*" ".*" # 查看用户的权限
rabbitmqctl list_user_permissions username

2.7 添加插件

# 添加web管理插件
rabbitmq-plugins enable rabbitmq_management # 添加移除异常消息的插件
rabbitmq-plugins enable rabbitmq_shovel rabbitmq_shovel_management # 下载延迟队列插件rabbitmq_delayed_message_exchange,得到ez文件
# mq插件位置/usr/lib/rabbitmq/lib/rabbitmq_server/plugins
# 下载网站 https://www.rabbitmq.com/community-plugins.html
rabbitmq-plugins enable rabbitmq_delayed_message_exchange # 添加成功后访问 http://ip地址:15672

2.8 编辑远程连接权限

vim /etc/rabbitmq/rabbitmq.config

2.9 追加以下内容,lucky为允许远程连接的用户

[

{rabbit, [{tcp_listeners, [5672]}, {loopback_users, ["username"]}]}

].

2.10 重启rabbitMQ

rabbitmqctl stop
rabbitmq-server restart
# 排查错误指令
systemctl status rabbitmq-server.service

2.11 访问http://IP地址:15672 进行管理

3.集群配置

3.1 Erlang通过erlang.cookie进行集群配置,配置RabbitMQ集群模式时需要各节点erlang.cookie内容一致

# 修改服务器配置 (.erlang.cookie只读)
vim /var/lib/rabbitmq/.erlang.cookie # 复制到其他节点
scp /var/lib/rabbitmq/.erlang.cookie root@10.104.132.37:/var/lib/rabbitmq/.erlang.cookie
scp /var/lib/rabbitmq/.erlang.cookie root@10.104.132.209:/var/lib/rabbitmq/.erlang.cookie # 未获取root密码情况下 需要更改权限,记得改回来
chmod 777 /var/lib/rabbitmq/.erlang.cookie
vim /var/lib/rabbitmq/.erlang.cookie
# 将两文件修改成一致后,改回原权限
chmod 400 /var/lib/rabbitmq/.erlang.cookie

3.2 使用 -detached 参数运行各节点

rabbitmqctl stop
rabbitmq-server -detached

3.3 修改主机的hostname和hosts

# 将HOSTNAME=ttt6-node35 确保两个服务器不一致
vim /etc/sysconfig/network
# 修改hosts
vim /etc/hosts

hosts内容需要和hostname保持一致 :举例

10.104.132.35     ttt6-node35
10.104.114.116 ttt6-node116

3.4 重启时配置生效,大约需要两分钟

reboot

3.5 在从服务器上执行下列语句加入集群

# 停止程序
rabbitmqctl stop_app
# 加入到集群,默认为磁盘节点
# 加入为内存节点 加-ram参数 如:rabbitmqctl join_cluster --ram rabbit@ttt6-node35
rabbitmqctl join_cluster rabbit@ttt6-node35
rabbitmqctl start_app

若出现 rabbitmqctl 指令执行不成功

检查Erlang cookie hash值是否一致,不一致重复3.1,注意空行

若一致,则可能是插件或者rabbitmq本身未启动

service rabbitmq-server start
rabbitmqctl start_app

3.6 查看集群搭建结果

 rabbitmqctl cluster_status

3.7 配置镜像队列模式,即队列会被复制到各个节点,各个节点状态保持一致,高可用

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

Linux 部署 rabbitMQ集群的更多相关文章

  1. RabbitMQ系列(五)使用Docker部署RabbitMQ集群

    概述 本文重点介绍的Docker的使用,以及如何部署RabbitMQ集群,最基础的Docker安装,本文不做过多的描述,读者可以自行度娘. Windows10上Docker的安装 因为本人用的是Win ...

  2. Docker swarm结合Openresty部署rabbitmq集群

    Docker swarm结合Openresty部署rabbitmq集群 大家好,年底了,年味儿越来越浓了.2019年的寒冬被定义为未来10年中最好的一年,对于这一说法悲观的人和乐观的人的理解是不一样的 ...

  3. k8s集群部署rabbitmq集群

    1.构建rabbitmq镜像 RabbitMQ提供了一个Autocluster插件,可以自动创建RabbitMQ集群.下面我们将基于RabbitMQ的官方docker镜像,添加这个autocluste ...

  4. Docker环境下的前后端分离项目部署与运维(八)使用Docker部署RabbitMQ集群

    下载RabbitMQ镜像 镜像地址RabbitMQ Docker官方认证镜像地址:https://hub.docker.com/_/rabbitmq 安装命令安装之前,切记把Docker Hub设置为 ...

  5. docker部署rabbitmq集群

    docker版本:18.09.6 或以上 rabbitmq镜像版本:rabbitmq:3.9.5-management 一.拉镜像: docker pull rabbitmq:3.9.5-manage ...

  6. CentOS 部署RabbitMQ集群

    1. 准备两台CentOS,信息如下: node1:10.0.0.123 node2:10.0.0.124 修改hostname请参照: $ hostname # 查看当前的hostname $ ho ...

  7. Linux 部署redis集群

    下载Redis 下载网址 http://www.redis.cn/download.html Redis需要gcc环境(如果已经有该环境跳过此步骤) yum install gcc-c++ 安装Red ...

  8. openstack(2) -------RabbitMQ集群部署

    一.RabbitMQ简介 RabbitMQ属于一个流行的开源消息队列系统.属于AMQP( 高级消息队列协议 ) 标准的一个 实现.是应用层协议的一个开放标准,为面向消息的中间件设计.用于在分布式系统中 ...

  9. RabbitMQ系列(六)你不知道的RabbitMQ集群架构全解

    前言 本文将系统的介绍一下RabbitMQ集群架构的特点.异常处理.搭建和使用中要注意的一些细节. 知识点 一.为什么使用集群? 二.集群的特点 三.集群异常处理 四.集群节点类型 五.集群搭建方法 ...

随机推荐

  1. Linux之恢复误删除文件

    前言每当我们在生产环境服务器上执行rm命令时,总是提心吊胆的,因为一不小心执行了误删,然后就要准备跑路了,毕竟人不是机器,更何况机器也有 bug.那么如果真的删除了不该删除的文件,比如数据库.日志或执 ...

  2. zhy2_rehat6_mysql02 - 5.7主从搭建.txt

    1.0------------锁库: mysql>FLUSH TABLES WITH READ LOCK; 这个命令是全局读锁定,执行了命令之后所有库所有表都被锁定只读.一般都是用在数据库联机备 ...

  3. 用PYTHON首选的GUI库WXPYTHON做程序界面

    大家好,我是A8U神经网络,今天又要跟大家分享一下wxWidgets开发神经网络程序界面的一些经验,希望对开发有兴趣的朋友有所帮助.跨平台的GUI工具库以GTK +,Qt和wxWidgets闻名. G ...

  4. 使用Active Database Duplication创建跨平台Data Guard设置 (Windows/Linux) (Doc ID 881421.1)

    Using Active Database Duplication to Create Cross Platform Data Guard Setup (Windows/Linux) (Doc ID ...

  5. Ribbon负载均衡及Feign消费者调用服务

    微服务调用Ribbon 简介 前面讲了eureka服务注册与发现,但是结合eureka集群的服务调用没讲. 这里的话 就要用到Ribbon,结合eureka,来实现服务的调用: Ribbon是Netf ...

  6. Python关于去除字符串中空格的方法

    Python关于去除字符串中空格的方法 在编写程序时我们经常会遇到需要将字符串中的空格去掉的情况,通常我们可以使用下面几种解决方法: 1.strip()方法:该方法只能把字符串头和尾的空格去掉,但是不 ...

  7. Linux下shell脚本实现mongodb定时自动备份

    MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功 ...

  8. 【algo&ds】【pat】5.并查集及其应用

    1.并查集的定义 在计算机科学中,并查集是一种树型的数据结构,用于处理一些不交集(Disjoint Sets)的合并及查询问题.有一个联合-查找算法(union-find algorithm)定义了两 ...

  9. 浅谈Kotlin中的函数

    本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/UV23Uw_969oVhiOdo4ZKAw作者:连凌能 Kotlin,已经被Android官方 ...

  10. 【nodejs原理&源码赏析(6)】深度剖析cluster模块源码与node.js多进程(下)

    目录 一. 引言 二.server.listen方法 三.cluster._getServer( )方法 四.跨进程通讯工具方法Utils 五.act:queryServer消息 六.轮询调度Roun ...