Docker部署Redis集群详解【主从复制 + 哨兵模式】

news2024/11/23 6:44:13

前言

注意:该文章不会讲解Redis集群搭建的原理,只讲述如何通过Docker容器快速部署搭建Redis主从 + 哨兵模式的集群

准备工作:

  • 一台云服务器 or 本地虚拟机(CentOS和Ubuntu都可以)
  • 安装好Docker环境(Docker、DockerCompose),参考6.3章节:https://blog.csdn.net/weixin_46594796/article/details/122750009
  • 关闭防火墙、开放将要使用的安全组(6379,6380,6381)

主从复制(1主2从)

这个操作很简单,在opt目录下创建docker-compose.yml文件,注释很详细,就不啰嗦了,内容如下:

version: '3.3'

# Docker网络:bridge驱动(默认) 
networks:
  redis-net:
    driver: bridge

services:
  # 主Redis
  redis-master:
    # Docker镜像版本
    image: redis:6.2.5
    # Docker容器名称
    container_name: redis-master
    # 主库Redis启动命令,密码为:123456
    command: redis-server --requirepass 123456
    # 宿主机与Docker容器的端口映射
    ports:
      - "6379:6379"
    # 容器所在的网络
    networks:
      - redis-net
  
  # 从Redis1
  redis-slave1:
    # Docker镜像版本
    image: redis:6.2.5
    # Docker容器名称
    container_name: redis-slave1
    # 启动命令:当前节点启动作为redis-master 6379的从库,主库密码为123456
    command: redis-server --slaveof redis-master 6379 --masterauth 123456
    # 宿主机与Docker容器的端口映射
    ports:
      - "6380:6379"
    # 启动该服务前先启动 redis-master
    depends_on:
      - redis-master
    # 容器所在的网络
    networks:
      - redis-net

  # 从Redis2
  redis-slave2:
    # Docker镜像版本
    image: redis:6.2.5
    # Docker容器名称
    container_name: redis-slave2
    # 启动命令:当前节点启动作为redis-master 6379的从库,主库密码为123456
    command: redis-server --slaveof redis-master 6379 --masterauth 123456
    # 启动该服务前先启动 redis-master
    depends_on:
      - redis-master
    # 宿主机与Docker容器的端口映射
    ports:
      - "6381:6379"
    # 容器所在的网络
    networks:
      - redis-net

直接启动Redis主从集群:

docker-compose up -d

查看三个Redis节点启动状态:

docker ps

通过Redis客户端为主Redis库插入一条数据后发现,从库也会同步主库中的数据了!

2、哨兵模式(3哨兵)

首先,在opt目录下创建config文件夹:

# 创建config目录
cd opt
mkdir config

重新调整docker-compose.yml,加入3个哨兵节点配置,然后docker-compose up -d启动:

version: '3.3'

# Docker网络:bridge驱动(默认) 
networks:
  redis-net:
    driver: bridge

services:
  # 主Redis
  redis-master:
    # Docker镜像版本
    image: redis:latest
    # Docker容器名称
    container_name: redis-master
    # 主库Redis启动命令,密码为:123456
    command: redis-server --requirepass 123456
    # 宿主机与Docker容器的端口映射
    ports:
      - "6379:6379"
    volumes:
      - /opt/config/master.conf:/etc/redis/master.conf
    # 容器所在的网络
    networks:
      - redis-net
  
  # 从Redis1
  redis-slave1:
    # Docker镜像版本
    image: redis:latest
    # Docker容器名称
    container_name: redis-slave1
    # 启动命令:当前节点启动作为redis-master 6379的从库,主库密码为123456
    command: redis-server --slaveof redis-master 6379 --masterauth 123456
    # 宿主机与Docker容器的端口映射
    ports:
      - "6380:6379"
    volumes:
      - /opt/config/slave1.conf:/etc/redis/slave1.conf
    # 启动该服务前先启动 redis-master
    depends_on:
      - redis-master
    # 容器所在的网络
    networks:
      - redis-net

  # 从Redis2
  redis-slave2:
    # Docker镜像版本
    image: redis:latest
    # Docker容器名称
    container_name: redis-slave2
    # 启动命令:当前节点启动作为redis-master 6379的从库,主库密码为123456
    command: redis-server --slaveof redis-master 6379 --masterauth 123456
    # 启动该服务前先启动 redis-master
    depends_on:
      - redis-master
    # 宿主机与Docker容器的端口映射
    ports:
      - "6381:6379"
    volumes:
      - /opt/config/slave2.conf:/etc/redis/slave2.conf
    # 容器所在的网络
    networks:
      - redis-net

  # Redis哨兵1
  redis-sentinel1:
    # Docker镜像版本
    image: redis:latest
    # Docker容器名称
    container_name: redis-sentinel-1
    # 启动命令:配置哨兵节点,监控主节点redis-master
    command: redis-sentinel /etc/redis/sentinel.conf
    # 宿主机与Docker容器的端口映射
    ports:
      - "26379:26379"
    volumes:
      - /opt/config/sentinel1.conf:/etc/redis/sentinel.conf
    # 启动该服务前先启动 redis-master 和 redis-slave1 和 redis-slave2
    depends_on:
      - redis-master
      - redis-slave1
      - redis-slave2
    # 容器所在的网络
    networks:
      - redis-net

  # Redis哨兵2
  redis-sentinel2:
    # Docker镜像版本
    image: redis:latest
    # Docker容器名称
    container_name: redis-sentinel-2
    # 启动命令:配置哨兵节点,监控主节点redis-master
    command: redis-sentinel /etc/redis/sentinel.conf
    # 宿主机与Docker容器的端口映射
    ports:
      - "26380:26379"
    volumes:
      - /opt/config/sentinel2.conf:/etc/redis/sentinel.conf
    # 启动该服务前先启动 redis-master 和 redis-slave1 和 redis-slave2
    depends_on:
      - redis-master
      - redis-slave1
      - redis-slave2
    # 容器所在的网络
    networks:
      - redis-net

  # Redis哨兵3
  redis-sentinel3:
    # Docker镜像版本
    image: redis:latest
    # Docker容器名称
    container_name: redis-sentinel-3
    # 启动命令:配置哨兵节点,监控主节点redis-master
    command: redis-sentinel /etc/redis/sentinel.conf
    # 宿主机与Docker容器的端口映射
    ports:
      - "26381:26379"
    volumes:
      - /opt/config/sentinel3.conf:/etc/redis/sentinel.conf
    # 启动该服务前先启动 redis-master 和 redis-slave1 和 redis-slave2
    depends_on:
      - redis-master
      - redis-slave1
      - redis-slave2
    # 容器所在的网络
    networks:
      - redis-net

在opt目录下创建sentinel.conf哨兵配置文件,将下方内容拷贝到文件中(根据情况自行调整):

port 26379
dir /tmp

# Sentinel 监视一个名为 mymaster 的主服务器(主Redis判断为失效至少需要 2 个 Sentinel 投票)
sentinel monitor mymaster <主Redis的IP> 6379 2 

# 授权主Redis密码
sentinel auth-pass mymaster 123456

# 指定了 Sentinel 认为服务器已经断线所需的毫秒数。
sentinel down-after-milliseconds mymaster 30000

# 指定了在执行故障转移时, 最多可以有多少个从服务器同时对新的主服务器进行同步, 
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 180000
sentinel deny-scripts-reconfig yes

将该配置文件拷贝三份(如果有同名文件先删除),文件名分别是:

  • sentinel1.conf
  • sentinel2.conf
  • sentinel3.conf

重启DockerCompose文件,依次执行下方命令:

docker-compose down
docker-compose up -d

接下来准备测试,通过docker ps查看一下6个节点运行情况:
在这里插入图片描述
停掉Redis主机点,看看是否会选举从节点为主节点:

# 停止主Redis节点
docker stop redis-master

# 查看哨兵节点日志
docker logs -f c277bfa6f0a8

下图可以看到,哨兵节点进行了投票选举,端口为6381的Redis从节点晋升为主节点
在这里插入图片描述
进入到6381的Redis容器内部,通过info命令查看当前节点身份:

# 进入Docker容器内部
docker exec -it 9b13c3a74734 redis-cli

# 查看身份
info

可以看到,6381的Redis节点变成了Master身份,哨兵进行了故障转移,重新选举
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/783528.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ROS框架——发布者功能包和订阅者功能包进行bool类型数据结构的topic通讯

ROS框架——发布者功能包和订阅者功能包进行bool类型数据结构的topic通讯 code review! 文章目录 ROS框架——发布者功能包和订阅者功能包进行bool类型数据结构的topic通讯零.同时运行两个功能包一.发布者功能包1.1.文件结构1.2.bool\_publisher\_node.cpp1.3.CMakeLists.txt…

SpringBoot实战(二十一)集成 TLog 日志

目录 一、简介二、Maven依赖三、启动类集成四、测试1.服务简介2.服务A代码DemoController.javaDemoFeignClient.java 3.服务B代码4.测试结果 补充一&#xff1a;自定义日志标签模板补充二&#xff1a;SpanId的生成规则补充三&#xff1a;业务标签1.打印入参2.指定连接符3.打印常…

【深度学习-卷积神经网络CNN-基础】

文章目录 发展历史卷积神经网络的应用领域卷积的原理和作用卷积和传统的神经网络的区别 卷积网络的整体架构输入层卷积层池化层全连接层卷积和池化叠加多层卷积可以处理什么类型的数据卷积的超参数卷积最大的优势 卷积的细节卷积的原理卷积的参数卷积的次数步长 卷积核尺寸 边缘…

成为UI设计高手:如何规划和创建UI设计组件库!

今天给大家分享一篇关于组件化设计的总结&#xff0c;希望可以带给大家更多设计思考。 什么是组件化 组件化化是构成界面的最基础元素和重复出现控件的集合体&#xff0c;也就是常说的组件库。通过对基础元素和控件的规范命名与排列组合&#xff0c;最终形成一个可快速调用与便…

每日一题——地下迷宫(迷宫问题II)

迷宫问题&#xff08;地下迷宫&#xff09;——II 题目链接 前言&#xff1a; 这题是在昨天迷宫问题——I的基础上进行的变形&#xff0c;因此&#xff0c;如果昨天的题目没看或者对迷宫问题不怎么了解&#xff0c;建议先看看昨天的解析。 迷宫问题——I源代码&#xff1a; …

安装redis,适配阿里云服务器,Liunx安装redis

下载redis以及编译安装 下载redis文件 wget http://download.redis.io/releases/redis-6.0.8.tar.gz #下载redis压缩文件 tar xzf redis-6.0.8.tar.gz #解压缩 cd redis-6.0.8 make 查看是否安装了gcc编译输入gcc --version如果没有…

AtcoderABC236场

A - chukodaiA - chukodai 题目大意 题目要求交换字符串S中第a个字符和第b个字符的位置&#xff0c;并输出结果。 思路分析 借用临时变量t&#xff0c;进行记录交换。 时间复杂度 O(∣S∣) 输出交换后的字符串的时间复杂度为O(∣S∣)&#xff0c;其中∣S∣表示字符串SS的…

autohotkey实战:窗口透明化

文章目录 实现方法代码讲解WinGet和WinSet 注 本文采用的是V1版本语法 实现方法 窗口透明不仅实用性强&#xff0c;关键是非常炫酷&#xff0c;如果用AHK实现一个实时调节窗口透明度的工具&#xff0c;那么就可以一边敲代码&#xff0c;一边透过半透明的IDE&#xff0c;愉快地…

vue 3.0 如何实现 文本框只能输入数字 避免文字和符号

<input v-model.number"form.payTime" :min"0" type"number" οninput"valuevalue.replace(/[^0-9.]/g,)" type"text" /> v-model 后面的.numer 一定要加上不然没效果 οninput"valuevalue.replace(/[^0-9.]/g…

Pdb蛋白质数据库网址!+30蛋白质数据库网站!

蛋白质数据库是指专门存储蛋白质相关信息的数据库。它们收集、整理和存储大量的蛋白质数据&#xff0c;包括蛋白质序列、结构、功能、互作关系、表达模式、疾病关联等信息。蛋白质数据库提供了对这些数据的检索、查询和分析功能&#xff0c;为科学研究人员、生物信息学家和药物…

为什么deferred probe将设备挂入延迟链表而不是将驱动挂入延迟链表

1. 代码流程(drivers/base/dd.c) 可以看到在probe失败的时候(驱动返回-EPROBE_DEFER)是把设备挂到deferred_probe_pending_list上面的。 这就带来了一个疑问: 我当前明明是驱动加载的过程(driver_attach()->bus_for_each_dev()), 为什么要将设备挂到pending list上面而不是…

Maven高级(继承与聚合+私服)

分模块设计和开发 为什么要分模块设计&#xff1f; 一个项目往往是分为好几个模块的 如果不同模块全写在一个项目里面 所有的程序员都要调用这有个项目就难以维护 比如我们之前设计的板块 就不太合理&#xff0c;现在我们把实体类和对应的工具类单独开出两个maven模块存储 然…

安装openai和简单使用

Anaconda的界面创建open ai环境&#xff0c;选择python10 控制台 #或者 conda info -e 注意不是anaconda命令开头 (base) C:\Users\su>conda env list # conda environments: # base * F:\anaconda3 openai F:\anaconda3\envs\opena…

TCP的拥塞控制、提高网络利用率的方法【TCP原理(笔记四)】

文章目录 拥塞控制慢启动 提高网络利用率的规范Nagle算法延迟确认应答捎带应答 拥塞控制 有了TCP的窗口控制&#xff0c;收发主机之间即使不再以一个数据段为单位发送确认应答&#xff0c;也能够连续发送大量数据包。然而&#xff0c;如果在通信刚开始时就发送大量数据&#x…

新能源汽车交流充电桩CP信号详解

随着新能源汽车的推广&#xff0c;交流充电桩迎来了巨大的市场需求&#xff0c;人们对车辆充电的便利性、安全性有着越来越高的要求。CP信号主要用于交流充电桩&#xff0c;充电桩和汽车之间只能通过CP信号进行通讯&#xff0c;判断、控制充电电流和状态。 汽车充电桩CP信号…

QT之自定义表格控件

继承QWidget来绘制的一款自定义控件&#xff0c;设计原因是因为Qt自带的QTableWidget的大批量操作很卡&#xff0c;特别是在嵌入式设备上时。 该控件特色功能&#xff1a; 1、支持拖动自适应。 2、支持各种颜色&#xff0c;字体&#xff0c;行列数设置。 代码如下&#xff1a; …

win10安装cuda11.4及cudnn

查看nvidia驱动版本 在windows终端键入nvidia-smi&#xff0c;查看nvidia显卡驱动。显卡驱动的版本决定了CUDA的版本下限。 如果出现上述的问题&#xff0c;则终端进入C:\Program Files\NVIDIA Corporation\NVSMI文件夹内&#xff0c;再键入nvidia-smi&#xff0c;可以看到我…

[MySQL]MySQL视图特性

[MySQL]MySQL视图特性 文章目录 [MySQL]MySQL视图特性1. 视图的概念2. 视图的基本操作创建视图删除视图 3. 视图规则和限制 1. 视图的概念 视图是一个虚拟表&#xff0c;其内容由查询定义&#xff0c;同真实的表一样&#xff0c;视图包含一系列带有名称的列和行数据。基表是对…

Git标签管理(对版本打标签,起别名)

tag 理解标签创建标签git tag [name]git show [tagname] 操作标签删除标签git tag -d < tagname > 推送某个标签到远程git push origin < tagname > 理解标签 标签 tag &#xff0c;可以简单的理解为是对某次 commit 的⼀个标识&#xff0c;相当于起了⼀个别名。 …

数据库备份mysqldump、mydumper、xtrabackup

数据库备份&#xff0c;数据库为school&#xff0c;素材如下 1.创建student和score表 CREATE TABLE student ( id INT(10) NOT NULL UNIQUE PRIMARY KEY , name VARCHAR(20) NOT NULL , sex VARCHAR(4) , birth YEAR, department VARCHAR(20) , address VARCHAR(50) );创建sco…