RabbitMQ高可用集群的搭建部署(Centos7)
高可用集群架构
节点域名 | 操作系统 | 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)的更多相关文章
- CentOS下RabbitMq高可用集群环境搭建
准备工作 1,准备两台或多台安装有rabbitmq-server服务的服务器 我这里准备了两台,分别如下: 192.168.40.130 rabbitmq01192.168.40.131 rabbit ...
- Linux源码安装RabbitMQ高可用集群
1.环境说明 linux版本:CentOS Linux release 7.9.2009 erlang版本:erlang-24.0 rabbitmq版本:rabbitmq_server-3.9.13 ...
- Redis总结(五)缓存雪崩和缓存穿透等问题 Web API系列(三)统一异常处理 C#总结(一)AutoResetEvent的使用介绍(用AutoResetEvent实现同步) C#总结(二)事件Event 介绍总结 C#总结(三)DataGridView增加全选列 Web API系列(二)接口安全和参数校验 RabbitMQ学习系列(六): RabbitMQ 高可用集群
Redis总结(五)缓存雪崩和缓存穿透等问题 前面讲过一些redis 缓存的使用和数据持久化.感兴趣的朋友可以看看之前的文章,http://www.cnblogs.com/zhangweizhon ...
- centos HA高可用集群 heartbeat搭建 heartbeat测试 主上停止heartbeat服务 测试脑裂 两边都禁用ping仲裁 第三十二节课
centos HA高可用集群 heartbeat搭建 heartbeat测试 主上停止heartbeat服务 测试脑裂 两边都禁用ping仲裁 第三十二节课 heartbeat是Linu ...
- Mysql双主双从高可用集群的搭建且与MyCat进行整合
1.概述 老话说的好:瞻前顾后.患得患失只会让我们失败,下定决心,干就完了. 言归正传,之前我们聊了Mysql的一主一从读写分离集群的搭建,虽然一主一从或一主多从集群解决了并发读的问题,但由于主节点只 ...
- RabbitMQ学习系列(六): RabbitMQ 高可用集群
前面讲过一些RabbitMQ的安装和用法,也说了说RabbitMQ在一般的业务场景下如何使用.不知道的可以看我前面的博客,http://www.cnblogs.com/zhangweizhong/ca ...
- ElasticSearch高可用集群环境搭建和分片原理
1.ES是如何实现分布式高并发全文检索 2.简单介绍ES分片Shards分片技术 3.为什么ES主分片对应的备分片不在同一台节点存放 4.索引的主分片定义好后为什么不能做修改 5.ES如何实现高可用容 ...
- SpringCloud之Eureka高可用集群环境搭建
注册中心集群 在微服务中,注册中心非常核心,可以实现服务治理,如果一旦注册出现故障的时候,可能会导致整个微服务无法访问,在这时候就需要对注册中心实现高可用集群模式. Eureka集群相当简单:相互注册 ...
- rabbitmq+haproxy+keepalived高可用集群环境搭建
1.先安装centos扩展源: # yum -y install epel-release 2.安装erlang运行环境以及rabbitmq # yum install erlang ... # yu ...
- Kubernetes实战:高可用集群的搭建和部署
摘要:官方只提到了一句"使用负载均衡器将 apiserver 暴露给工作节点",而这恰恰是部署过程中需要解决的重点问题. 本文分享自华为云社区<Kubernetes 高可用集 ...
随机推荐
- 【译】基于XAML的跨平台框架对比分析
多年来,基于XAML的UI框架已经有了很大的发展.下面的图表是最好的说明.这些框架主要包含:支持跨平台应用的Avalonia UI, Uno Platform和 .NET MAUI.事实上,除了Ava ...
- WorkManager的用法
一.WorkManager的作用 绝大部分应用程序都有后台执行任务的需求,根据需求的不同,Android为后台任务提供了多种解决方案,如JobShedule,Loader,Service等.如果这些a ...
- 深入理解Linux内核——内存管理(1)
提要:本系列文章主要参考MIT 6.828课程以及两本书籍<深入理解Linux内核> <深入Linux内核架构>对Linux内核内容进行总结. 内存管理的实现覆盖了多个领域: ...
- 如何在Vue3中配置国际化语言i18n
1. 安装 vue-i18n npm i vue-i18n -S 2. 创建一个i8n的配置文件 如:i18nConfig.js // 配置 vue-i18n 实现国际化语言设置 import { c ...
- 「luogu - P3911」最小公倍数之和
link. Denote \(cnt_{x}\) = the number of occurrences of \(x\), \(h\) = the maximum of \(a_i\), there ...
- 给定3个整数a、b、c,计算表达式(a+b)/c的值,/是整除运算。[无解]
题目4-2:给定3个整数a.b.c,计算表达式(a+b)/c的值,/是整除运算. 给定3个整数a.b.c,计算表达式(a+b)/c的值,/是整除运算. 输入格式:输入仅一行,包括三个 整数a.b.c, ...
- http 500 错误
214 [Thu Sep 09 16:03:54.919334 2021] [:error] [pid 32045] [client 124.238.184.230:23796] script '/v ...
- CUDA C编程权威指南:2.2-给核函数计时
本文主要通过例子介绍了如何给核函数计时的思路和实现.实现例子代码参考文献[7],只需要把相应章节对应的CMakeLists.txt文件拷贝到CMake项目根目录下面即可运行. 1.用CPU计时器计 ...
- Skywalking APM监控系列(二、Mysql、Linux服务器与前端JS接入Skywalking监听)
前言 上篇我们介绍了Skywalking的基本概念与如何接入.Net Core项目,感兴趣可以去看看: Skywalking APM监控系列(一丶.NET5.0+接入Skywalking监听) 本篇我 ...
- CF1352D
题目简化和分析: 这题可以直接按照题意进行模拟,当然有些细节需要注意. 翻译的不足:这里的回合指任意一个人吃掉都算,而不是双方一个回合,最后一个人即使不满足也算一个回合. 我们可以采用两个指针模拟两个 ...