使用DockerCompose配置基于哨兵模式的redis主从架构集群

2024-04-15 23:36

本文主要是介绍使用DockerCompose配置基于哨兵模式的redis主从架构集群,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、注意事项(坑点!!!)
    • 二、配置Redis主从架构集群
      • 第一步:创建目录文件结构
      • 第二步:编写DockerCompose配置文件
      • 第三步:编写redis.conf
      • 第四步:启动redis主从集群
    • 三、配置哨兵
      • 第一步:编写DockerCompose配置文件
      • 第二步:获取master在容器中的ip
      • 第三步:编写sentinel.conf
      • 第四步:启动哨兵
    • 四、测试从机自动升级效果
      • 1. 测试联通性
      • 2.测试自动选举

使用DockerCompose配置单个redis环境可以参考另一篇文章【使用DockerCompose安装Redis】

一、注意事项(坑点!!!)

  1. 在slave配置指定master时(slaveof redis-master 6379),尽管master是配置映射的6380,但是端口还是要指定6379,这个端口必须是master容器内的端口,而不是映射到主机的端口。
  2. 配置sentinel.conf时,指定master要用ip或者域名,指定master的容器名无法通过(只有redis.conf里知道master时容器名可以通过,如果有朋友知道其中原理是什么,欢迎在评论区留言讨论)。
  3. 使用docker-compose down删除容器集群之后,下一次启动时master的ip可能变了,要重新查询master的ip并修改哨兵的配置文件

二、配置Redis主从架构集群

第一步:创建目录文件结构

# 进入docker相关文件目(没有可以参考文章顶部的文章创建一个)
cd /docker
# 创建相关目录
mkdir redis-master-slave redis-master-slave/master redis-master-slave/slave1 redis-master-slave/slave2

第二步:编写DockerCompose配置文件

vim /docker/docker-compose/redis-master-slave.yml

写入以下内容

version: '3' 
services:# ------------------- master ------------------- redis-master:image: redis:6.2.14container_name: redis-masterports:- 6380:6379volumes:- /docker/redis-master-slave/master/redis.conf:/usr/local/etc/redis/redis.conf- /docker/redis-master-slave/master/data:/data- /docker/redis-master-slave/master/logs:/var/log/rediscommand: redis-server /usr/local/etc/redis/redis.confrestart: always# ------------------- slave1 ------------------- redis-slave1:image: redis:6.2.14container_name: redis-slave1ports:- 6381:6379volumes:- /docker/redis-master-slave/slave1/redis.conf:/usr/local/etc/redis/redis.conf- /docker/redis-master-slave/slave1/data:/data- /docker/redis-master-slave/slave1/logs:/var/log/rediscommand: redis-server /usr/local/etc/redis/redis.confrestart: always# ------------------- slave2 ------------------- redis-slave2:image: redis:6.2.14container_name: redis-slave2ports:- 6382:6379volumes:- /docker/redis-master-slave/slave2/redis.conf:/usr/local/etc/redis/redis.conf- /docker/redis-master-slave/slave2/data:/data- /docker/redis-master-slave/slave2/logs:/var/log/rediscommand: redis-server /usr/local/etc/redis/redis.confrestart: always

第三步:编写redis.conf

1. 配置master的redis.conf

vim /docker/redis-master-slave/master/redis.conf

写入以下内容

# 配置密码
requirepass 123456
# 开启aof
appendonly yes 
# aof文件名
appendfilename "appendonly.aof"
# aof记录的策略                                                                                                                                      
appendfsync always
# appendfsync everysec
# appendfsync no

2. 配置slave1的redis.conf
注意slave的6379是容器内的端口,如果没必须是6379

vim /docker/redis-master-slave/slave1/redis.conf

写入以下内容

# 配置密码
requirepass 123456
# 开启aof
appendonly yes 
# aof文件名
appendfilename "appendonly.aof"
# aof记录的策略
appendfsync always
# appendfsync everysec
# appendfsync no# 指定master
slaveof redis-master 6379
# 指定master的密码                                                                                                                                   
masterauth 123456

4. 配置slave2的redis.conf

vim /docker/redis-master-slave/slave2/redis.conf

写入以下内容(和slave1一模一样)

# 配置密码
requirepass 123456
# 开启aof
appendonly yes 
# aof文件名
appendfilename "appendonly.aof"
# aof记录的策略
appendfsync always
# appendfsync everysec
# appendfsync no# 指定master
slaveof redis-master 6379
# 指定master的密码                                                                                                                                   
masterauth 123456

第四步:启动redis主从集群

cd /docker/docker-compose
docker-compose -f redis-master-slave.yml up -d

启动后使用docker ps 命令查看状态

在这里插入图片描述

补充:

  • 停用:docker-compose -f redis-master-slave.yml down

三、配置哨兵

可以配置一个,也可以配置多个,当然配置多个哨兵的话,才更能保证高可用。这里我就只配置一个,配置多个几乎是一模一样的配置,只是端口变一下。

第一步:编写DockerCompose配置文件

vim /docker/docker-compose/redis-ms-sentinal.yml

写入以下内容

version: '3' 
services:# ------------------- sentinel ------------------- redis-sentinel:image: redis:6.2.14container_name: redis-sentinelports:- 26379:26379volumes:- /docker/redis-master-slave/sentinel.conf:/usr/local/etc/redis/sentinel.confcommand: redis-sentinel /usr/local/etc/redis/sentinel.conf                                                                                       restart: always

第二步:获取master在容器中的ip

使用 docker inspect 容器id|grep IPAddress命令,如下
在这里插入图片描述

第三步:编写sentinel.conf

vim /docker/redis-master-slave/sentinel.conf 

写入以下内容(主义填入正确的 master ip

port 26379
# 哨兵    监视   主机名      主机ip    端口 票数
sentinel monitor mymaster 192.168.48.5 6379 1
# 集群的密码
sentinel auth-pass mymaster 123456

第四步:启动哨兵

cd /docker/docker-compose
docker-compose -f redis-ms-sentinal.yml up -d

启动后使用docker ps 命令查看状态

在这里插入图片描述

四、测试从机自动升级效果

1. 测试联通性

在这里插入图片描述

2.测试自动选举

通过流言协议和投票协议进行重新选举需要几秒钟的时间
在这里插入图片描述

这篇关于使用DockerCompose配置基于哨兵模式的redis主从架构集群的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/907233

相关文章

使用@Slf4j注解,log.info()无法使用问题

《使用@Slf4j注解,log.info()无法使用问题》在使用Lombok的@Slf4j注解打印日志时遇到问题,通过降低Lombok版本(从1.18.x降至1.16.10)解决了问题... 目录@Slf4androidj注解,log.info()无法使用问题最后解决总结@Slf4j注解,log.info(

Nacos集群数据同步方式

《Nacos集群数据同步方式》文章主要介绍了Nacos集群中服务注册信息的同步机制,涉及到负责节点和非负责节点之间的数据同步过程,以及DistroProtocol协议在同步中的应用... 目录引言负责节点(发起同步)DistroProtocolDistroSyncChangeTask获取同步数据getDis

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

HDFS—集群扩容及缩容

白名单:表示在白名单的主机IP地址可以,用来存储数据。 配置白名单步骤如下: 1)在NameNode节点的/opt/module/hadoop-3.1.4/etc/hadoop目录下分别创建whitelist 和blacklist文件 (1)创建白名单 [lytfly@hadoop102 hadoop]$ vim whitelist 在whitelist中添加如下主机名称,假如集群正常工作的节