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 高可用集 ...
随机推荐
- 聚焦Web前端安全:最新揭秘漏洞防御方法
在 Web 安全中,服务端一直扮演着十分重要的角色.然而前端的问题也不容小觑,它也会导致信息泄露等诸如此类的问题.在这篇文章中,我们将向读者介绍如何防范Web前端中的各种漏洞.[万字长文,请先收藏再阅 ...
- K210 调节颜色阈值识别红绿黄三色
官方在机器视觉的API中提供了寻找绿色色块的例程 https://wiki.sipeed.com/soft/maixpy/zh/api_reference/machine_vision/image/i ...
- 推荐一款免费好用的远程桌面:Getscreen
因为平时有多台设备要用,所以远程桌面是我经常要使用的工具. 最近,正好看到一款不错的远程桌面软件,马上拿出来推荐给大家,如果有需要的可以看看. 今天要推荐的远程桌面软件就是这款叫Getscreen的软 ...
- 20个最佳实践提升Terraform工作流程|Part 1
Terraform 是管理基础设施及代码(IaC)最常用的工具之一,它能使我们安全且可预测地对基础设施应用更改.刚开始上手 Terraform 可能会感觉有些不容易,但很快就能对该工具有基本的了解,随 ...
- 路由器与交换机:Access/Trunk,Wan/Lan
转载请注明出处: 1.交换机与路由器 交换机与路由器的特点: 交换机(Switch): 用于在局域网中传输数据帧 基于MAC地址进行转发和过滤 工作在数据链路层(第二层) 具有多个端口,可以连接多台计 ...
- Solution -「CF 1477A」Nezzar and Board
Description Link. $ n $ distinct integers $ x_1,x_2,\ldots,x_n $ are written on the board. Nezzar ca ...
- ES6-ES11最通俗易懂保姆级的笔记!人见人爱,花见花开。赶快动起你发财的小手收藏起来吧,满满的干货,你值得拥有!!
1. ES6 1.1 let变量声明以及声明特性 声明变量 let a; let b, c, e; let f = 100, g = "红石榴21", h = []; 特性: ...
- Azure Data Factory(九)基础知识回顾
一,引言 在本文中,我们将继续了解什么是 Azure Data Factory,Azure Data Factory 的工作原理,Azure Data Factory 数据工程中的数据管道,并了解继承 ...
- fopen各个模式区别
fopen 函数是C标准库中用于打开文件的函数,它接受一个文件名和一个打开模式作为参数,返回一个指向文件的指针. 这里解释各个模式的区别: "r": 以只读模式打开文件,文件必须存 ...
- 造轮子之EventBus
前面基础管理的功能基本开发完了,接下来我们来优化一下开发功能,来添加EventBus功能.EventBus也是我们使用场景非常广的东西.这里我会实现一个本地的EventBus以及分布式的EventBu ...