高可用集群架构

节点域名 操作系统 RabbitMQ版本 Erlang版本
iamdemo.tp-link.com Centos7.9 3.8.28 23.3-2
iamdemo2.tp-link.com Centos7.9 3.8.28 23.3-2
iamdemo3.tp-link.com Centos7.9 3.8.28 23.3-2
目前Centos7.9通过直接RPM包部署安装的版本最高支持到3.8.28,Erlang相应版本支持范围为23.2到24.2,也通过RPM包安装部署
RabbitMQ 3.8.28 RPM包下载地址: https://github.com/rabbitmq/rabbitmq-server/releases/tag/v3.8.28
Erlang 23.3-2 RPM包下载地址: https://github.com/rabbitmq/erlang-rpm/releases/tag/v23.3
本文采用搭建RabbitMQ镜像队列+前端LB负载均衡健康监测+Autoheal自动恢复策略 来实现高可用

部署步骤

配置/etc/hosts

配置集群节点的别名(域名劫持)
172.29.145.157 iamdemo.tp-link.com iamdemo1
172.29.145.182 iamdemo2.tp-link.com iamdemo2
172.29.145.183 iamdemo3.tp-link.com iamdemo3

所有节点 安装RabbitMQ和Erlang

[root@iamdemo1 ~]# rpm -ivh erlang-23.3-2.el7.x86_64.rpm
[root@iamdemo1 ~]# rpm -ivh rabbitmq-server-3.8.28-1.el7.noarch.rpm

复制erlang.cookie

文件位置: /var/lib/rabbitmq/.erlang.cookie
通过scp将一节点的erlang.cookie传输到其他集群节点,从而保证节点之间能够通信

安装相关依赖

[root@iamdemo1 ~]# yum -y install socat

编写配置文件Rabbitmq.conf

文件位置: /etc/rabbitmq/rabbitmq.conf

listeners.tcp.default = 5672 ##Rabbitmq节点监听端口
management.listener.port = 15672 ##UI管理界面端口
management.listener.ssl = false
default_permissions.configure = .*
default_permissions.read = .*
default_permissions.write = .*
cluster_partition_handling = autoheal ##自动恢复策略
log.file = /var/log/rabbitmq/rabbitmq.log ##日志配置路径
log.file.level = info ##日志记录等级
cluster_formation.peer_discovery_backend = rabbit_peer_discovery_classic_config ##集群自动发现
vm_memory_high_watermark.relative = 0.6 ##内存高水位阈值,生产环境推荐设置为0.6(默认0.4)

应用UI界面管理插件

[root@iamdemo1 rabbitmq]# rabbitmq-plugins enable rabbitmq_management

启动Rabbitmq三个节点

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

二三节点加入集群

注意: 这一步启动完二三节点后需要先使用rabbitmqctl stop_app先关闭rabbitmq服务
systemctl stop rabbitmq-server和rabbitmqctl stop_app的区别就是前者会关闭Erlang服务 [root@iamdemo2 ~]# rabbitmqctl reset ##清除内容再加入集群,已有数据的节点谨慎操作,数据会丢失
[root@iamdemo2 ~]# rabbitmqctl join_cluster rabbit@iamdemo1 ##加入一节点的集群 如果不知道后面这个rabbit@iamdemo1该如何填写,就去一节点上运行rabbitmqctl cluster_status查看
【Disk Nodes】
rabbit@iamdemo1
rabbit@iamdemo2
rabbit@iamdemo3
【Running Nodes】
rabbit@iamdemo1
rabbit@iamdemo2
rabbit@iamdemo3 [root@iamdemo2 rabbitmq]# rabbitmqctl join_cluster rabbit@iamdemo1
Clustering node rabbit@iamdemo2 with rabbit@iamdemo1(成功会像这样显示)
然后再使用Rabbitmqctl start_app启动服务,这时候再查看集群状态就发现三个节点已加入到一个集群了~
[root@iamdemo1 rabbitmq]# rabbitmqctl cluster_status 【Versions】
rabbit@iamdemo1: RabbitMQ 3.8.28 on Erlang 23.3
rabbit@iamdemo2: RabbitMQ 3.8.28 on Erlang 23.3
rabbit@iamdemo3: RabbitMQ 3.8.28 on Erlang 23.3

创建用户并授权

[root@iamdemo1 ~]# rabbitmqctl add_user admin admin ##创建admin用户,现在UI界面不允许初始root用户登录
[root@iamdemo1 ~]# rabbitmqctl set_user_tags admin administrator ##授予admin用户管理员权限
[root@iamdemo1 ~]# rabbitmqctl set_permissions -p / admin "." "." ".*" ##设置访问策略

登录UI管理界面进行管理

your_website.com:15672 就可以使用admin/admin登录了!

RabbitMQ高可用集群的搭建部署(Centos7)的更多相关文章

  1. CentOS下RabbitMq高可用集群环境搭建

    准备工作 1,准备两台或多台安装有rabbitmq-server服务的服务器 我这里准备了两台,分别如下: 192.168.40.130 rabbitmq01192.168.40.131 rabbit ...

  2. Linux源码安装RabbitMQ高可用集群

    1.环境说明 linux版本:CentOS Linux release 7.9.2009 erlang版本:erlang-24.0 rabbitmq版本:rabbitmq_server-3.9.13 ...

  3. Redis总结(五)缓存雪崩和缓存穿透等问题 Web API系列(三)统一异常处理 C#总结(一)AutoResetEvent的使用介绍(用AutoResetEvent实现同步) C#总结(二)事件Event 介绍总结 C#总结(三)DataGridView增加全选列 Web API系列(二)接口安全和参数校验 RabbitMQ学习系列(六): RabbitMQ 高可用集群

    Redis总结(五)缓存雪崩和缓存穿透等问题   前面讲过一些redis 缓存的使用和数据持久化.感兴趣的朋友可以看看之前的文章,http://www.cnblogs.com/zhangweizhon ...

  4. centos HA高可用集群 heartbeat搭建 heartbeat测试 主上停止heartbeat服务 测试脑裂 两边都禁用ping仲裁 第三十二节课

    centos   HA高可用集群  heartbeat搭建 heartbeat测试  主上停止heartbeat服务  测试脑裂  两边都禁用ping仲裁  第三十二节课 heartbeat是Linu ...

  5. Mysql双主双从高可用集群的搭建且与MyCat进行整合

    1.概述 老话说的好:瞻前顾后.患得患失只会让我们失败,下定决心,干就完了. 言归正传,之前我们聊了Mysql的一主一从读写分离集群的搭建,虽然一主一从或一主多从集群解决了并发读的问题,但由于主节点只 ...

  6. RabbitMQ学习系列(六): RabbitMQ 高可用集群

    前面讲过一些RabbitMQ的安装和用法,也说了说RabbitMQ在一般的业务场景下如何使用.不知道的可以看我前面的博客,http://www.cnblogs.com/zhangweizhong/ca ...

  7. ElasticSearch高可用集群环境搭建和分片原理

    1.ES是如何实现分布式高并发全文检索 2.简单介绍ES分片Shards分片技术 3.为什么ES主分片对应的备分片不在同一台节点存放 4.索引的主分片定义好后为什么不能做修改 5.ES如何实现高可用容 ...

  8. SpringCloud之Eureka高可用集群环境搭建

    注册中心集群 在微服务中,注册中心非常核心,可以实现服务治理,如果一旦注册出现故障的时候,可能会导致整个微服务无法访问,在这时候就需要对注册中心实现高可用集群模式. Eureka集群相当简单:相互注册 ...

  9. rabbitmq+haproxy+keepalived高可用集群环境搭建

    1.先安装centos扩展源: # yum -y install epel-release 2.安装erlang运行环境以及rabbitmq # yum install erlang ... # yu ...

  10. Kubernetes实战:高可用集群的搭建和部署

    摘要:官方只提到了一句"使用负载均衡器将 apiserver 暴露给工作节点",而这恰恰是部署过程中需要解决的重点问题. 本文分享自华为云社区<Kubernetes 高可用集 ...

随机推荐

  1. 一文详解自然语言处理两大任务与代码实战:NLU与NLG

    自然语言处理(NLP)涵盖了从基础理论到实际应用的广泛领域,本文深入探讨了NLP的关键概念,包括词向量.文本预处理.自然语言理解与生成.统计与规则驱动方法等,为读者提供了全面而深入的视角. 作者 Te ...

  2. Dokcer学习之旅(1)——运行一个简单的容器

    基本概念 镜像 我们都知道,操作系统分为 内核 和 用户空间.对于 Linux 而言,内核启动后,会挂载 root 文件系统为其提供用户空间支持.而 Docker 镜像(Image),就相当于是一个 ...

  3. 使用PySpark计算AUC,KS与PSI

    当特征数量或者模型数量很多的时候,使用PySpark去计算相关指标会节省很多的时间.网上关于使用PySpark计算相关指标的资料较少,这里抛砖引玉,写了三个风控常用的指标AUC,KS和PSI相关的计算 ...

  4. Python 基础面试第四弹

    1. Python中常用的库有哪些,作用分别是什么 requests: requests 是一个用于发送 HTTP 请求的库,它提供了简单而优雅的 API,可以轻松地发送 GET.POST.PUT.D ...

  5. Solution -「THUPC 2021」区间矩阵乘法

    Description Link. 给定长度为 \(n\) 的序列 \(a_1, a_2, \dots, a_n\):共 \(m\) 组询问,每次询问给出 \(d,p_1,p_2\),求 \[\sum ...

  6. Note -「virtual tree」shorter vrt

    Part. 1 Preface 没什么 preface. Part. 2 实现 具体来说就是把所有关键点按 \(\text{dfn}\) 排序,去重,然后求出相邻结点的 \(\text{LCA}\), ...

  7. Springboot+Mybatisplus+ClickHouse集成

    核心依赖引入 <dependency> <groupId>ru.yandex.clickhouse</groupId> <artifactId>clic ...

  8. 教育法学第六章单元测试MOOC

    第六章单元测试 返回 本次得分为:100.00/100.00, 本次测试的提交时间为:2020-09-06, 如果你认为本次测试成绩不理想,你可以选择 再做一次 . 1 单选(5分) "学习 ...

  9. 【纯干货】IOS手机使用Charles抓包

    一.Charles 下载地址 https://www.charlesproxy.com/ 二.Charles 激活 1.生成激活码 生成激活码:https://www.zzzmode.com/myto ...

  10. Python join拼接

    import os print(os.path.join("I","love","you.")) # /XXX 代表的是绝对路径 这个变量之 ...