一篇博客教会你使用Docker部署Redis哨兵

news2024/12/29 8:43:01

文章目录

  • 主数据库
    • 配置文件
    • 启动实例
    • 容器虚拟IP
  • 从数据库
    • 配置文件
    • 启动实例
  • 主从数据库
    • 查看主数据库
    • 查看从数据库
  • 哨兵
    • 配置文件
    • 启动哨兵
    • 查看哨兵
  • 哨兵机制
    • 哨兵选举
    • 选举日志
    • 重启主数据库

今天我们学习使用 Docker 部署 Redis 的主从复制,并部署 Redis 哨兵,实现 Redis 数据库的高可用。

主数据库

如何使用 Docker 下载并启动一个 Redis 实例,我们在以前的博客 《一篇博客教会你怎么使用Docker安装Redis》 学习过,在本篇博客中就不过多赘述,有兴趣的同学可以移步到之前的博客学习。

配置文件

我们先将准备好的配置文件复制一份。

cp redis.conf redis-master.conf

启动实例

然后使用 Docker 命令,启动一个 Redis 数据库实例作为主数据库。

docker run -p 6380:6379 --name redis-master -v /etc/redis/redis-master.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf

容器虚拟IP

使用 Docker 命令,获取 Redis 实例的虚拟 ip 地址

docker inspect --format={{.NetworkSettings.IPAddress}} redis-master

从数据库

从数据相比较于主数据,需要配置从数据库对应的主数据的信息,即主数据的 ip 和端口,其中的 ip 即上述使用 Docker 命令获取的虚拟 ip 地址,而端口同样也是容器对应的虚拟端口,即为 Docker 容器内部对应的 6379,而不是容器外部的映射端口。

配置文件

将配置文件复制一份,作为从数据库的配置文件。

cp redis.conf redis-slave.conf

redis-slave.conf 配置文件的末尾添加主数据库的信息配置。

REPLICAOF 172.17.0.2 6379

启动实例

然后使用 Docker 命令,启动三个 Redis 数据库实例作为从数据库。

docker run -p 6381:6379 --name redis-slave1 -v /etc/redis/redis-slave.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf

docker run -p 6382:6379 --name redis-slave2 -v /etc/redis/redis-slave.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf

docker run -p 6383:6379 --name redis-slave3 -v /etc/redis/redis-slave.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf

主从数据库

我们可以使用 Docker 命令进入 Redis 的四个实例中,查看主从关系是否生效。

查看主数据库

使用命令查看主数据库的情况,从图中我们可以确认,该 Redis 实例为主数据库,共有三个从数据库。

docker exec -it redis-master bash

redis-cli

info Replication

在这里插入图片描述

查看从数据库

使用命令查看从数据库的情况,从图中我们可以确认,该 Redis 实例为从数据库及该从数据库对应的主数据库的具体信息。

docker exec -it redis-slave1 bash

redis-cli

info Replication

在这里插入图片描述

哨兵

我们使用 Docker 启动 Redis 实例作为哨兵。

配置文件

创建 sentinel.conf 文件,并在文件内编辑配置文件内容如下:

# 哨兵sentinel实例运行的端口 默认26379 
port 26379 
# 哨兵sentinel的工作目录 
dir /tmp 
# 哨兵sentinel监控的redis主节点的 ip port 
# master-name 可以自己命名的主节点名字 只能由字母A-z、数字0-9 、这三个字符".-_"组 成。
# quorum 当这些quorum个数sentinel哨兵认为master主节点失联 那么这时 客观上认为主节点 失联了 
# sentinel monitor <master-name> <ip> <redis-port> <quorum> 
sentinel monitor redis-master 172.17.0.2 6379 2
# 当在Redis实例中开启了requirepass foobared 授权密码 这样所有连接Redis实例的客户端都 要提供密码 
# 设置哨兵sentinel 连接主从的密码 注意必须为主从设置一样的验证密码 
# sentinel auth-pass <master-name> <password> 
sentinel auth-pass redis-master ""
# 指定多少毫秒之后 主节点没有应答哨兵sentinel 此时 哨兵主观上认为主节点下线 默认30秒 
# sentinel down-after-milliseconds <master-name> <milliseconds> 
sentinel down-after-milliseconds redis-master 30000 
# 这个配置项指定了在发生failover主备切换时最多可以有多少个slave同时对新的master进行同步
# 这个数字越小,完成failover所需的时间就越长,但是如果这个数字越大,就意味着越多的slave因为replication而不可用。 
# 可以通过将这个值设为 1 来保证每次只有一个slave 处于不能处理命令请求的状态。 
# sentinel parallel-syncs <master-name> <numslaves>
sentinel parallel-syncs redis-master 1

# 故障转移的超时时间 failover-timeout 可以用在以下这些方面: 
#1. 同一个sentinel对同一个master两次failover之间的间隔时间。 
#2. 当一个slave从一个错误的master那里同步数据开始计算时间。直到slave被纠正为向正确的 master那里同步数据时。 
#3.当想要取消一个正在进行的failover所需要的时间。 
#4.当进行failover时,配置所有slaves指向新的master所需的最大时间。不过,即使过了这个超 时,slaves依然会被正确配置为指向master,但是就不按parallel-syncs所配置的规则来了 
# 默认三分钟 
# sentinel failover-timeout <master-name> <milliseconds> 
sentinel failover-timeout redis-master 180000


# SCRIPTS EXECUTION 
# 配置当某一事件发生时所需要执行的脚本,可以通过脚本来通知管理员,例如当系统运行不正常时发邮 件通知相关人员。 
#对于脚本的运行结果有以下规则: 
#若脚本执行后返回1,那么该脚本稍后将会被再次执行,重复次数目前默认为10 
#若脚本执行后返回2,或者比2更高的一个返回值,脚本将不会重复执行。 
#如果脚本在执行过程中由于收到系统中断信号被终止了,则同返回值为1时的行为相同。 
#一个脚本的最大执行时间为60s,如果超过这个时间,脚本将会被一个SIGKILL信号终止,之后重新执 行。

#通知型脚本:当sentinel有任何警告级别的事件发生时(比如说redis实例的主观失效和客观失效等 等),将会去调用这个脚本,
#这时这个脚本应该通过邮件,SMS等方式去通知系统管理员关于系统不正 常运行的信息。调用该脚本时,将传给脚本两个参数,一个是事件的类型,一个是事件的描述。 
#如果sentinel.conf配置文件中配置了这个脚本路径,那么必须保证这个脚本存在于这个路径,并且 是可执行的,否则sentinel无法正常启动成功。

#通知脚本 
# sentinel notification-script <master-name> <script-path> 
# sentinel notification-script mymaster /var/redis/notify.sh

# 客户端重新配置主节点参数脚本 
# 当一个master由于failover而发生改变时,这个脚本将会被调用,通知相关的客户端关于master 地址已经发生改变的信息。 
# 以下参数将会在调用脚本时传给脚本: 
# <master-name> <role> <state> <from-ip> <from-port> <to-ip> <to-port> 
# 目前<state>总是“failover”, 
# <role>是“leader”或者“observer”中的一个。 
# 参数 from-ip, from-port, to-ip, to-port是用来和旧的master和新的master(即旧的 slave)通信的 
# 这个脚本应该是通用的,能被多次调用,不是针对性的。 
# sentinel client-reconfig-script <master-name> <script-path> 
# sentinel client-reconfig-script mymaster /var/redis/reconfig.sh

哨兵的配置文件内容较多,需要注意以下几点:

  • sentinel monitor redis-master 172.17.0.2 6379 2
    该配置为 Redis 主数据库的 ip 和端口,需要将其修改为自己启动的 Redis 主数据库的 ip 和端口。
    最后一个参数为哨兵投票成功的个数,不要大于哨兵的总实例个数。

  • sentinel auth-pass redis-master “”
    该配置为 Redis 主数据库的密码,如果没有,使用空串即可;如果有,需要配置密码,注意必须为主从数据库设置一样的验证密码

  • sentinel down-after-milliseconds redis-master 30000
    该配置为哨兵认为主数据库下线的时间,即主数据库下线或宕机之后 30000 毫秒,哨兵会主观认为主数据库真正下线。

启动哨兵

然后使用 Docker 命令,启动三个 Redis 数据库实例作为哨兵。

docker run -p 26379:26379 --name redis-sentinel1 -v /etc/redis/sentinel.conf:/etc/redis/sentinel.conf -d redis redis-sentinel /etc/redis/sentinel.conf

docker run -p 26380:26379 --name redis-sentinel2 -v /etc/redis/sentinel.conf:/etc/redis/sentinel.conf -d redis redis-sentinel /etc/redis/sentinel.conf

docker run -p 26381:26379 --name redis-sentinel3 -v /etc/redis/sentinel.conf:/etc/redis/sentinel.conf -d redis redis-sentinel /etc/redis/sentinel.conf

查看哨兵

使用命令查看哨兵的情况,从图中我们可以确认,该 Redis 哨兵已经启动成功,并获取了主数据库,从数据库,其他哨兵的信息。

docker logs -f redis-sentinel1

在这里插入图片描述

或者我们可以使用其他命令,进入哨兵实例的内部,查看实例信息,从图中我们可以看出,该 Redis 哨兵启动状态成功,其中有主数据库地址为 172.17.0.2:6379,从数据库3个,哨兵3个。

docker exec -it redis-sentinel1 bash

redis-cli -p 26379

info Sentinel

在这里插入图片描述

哨兵机制

哨兵选举

我们使用 DockerRedis 主数据库实例停止运行,模拟出主数据库因为意外情况下线或者宕机的情况。

docker stop redis-master

等候大约 30000 毫秒左右的时间,我们重新查看哨兵的情况。

docker exec -it redis-sentinel1 bash

redis-cli -p 26379

info Sentinel

在这里插入图片描述

第一个 info Sentinel 是因为时间还没有达到 30000 毫秒之后,哨兵还没有主观判断主数据库下线,而等候 30000 毫秒之后,数据库下线,于是哨兵自动从 3 个从数据库中选举了一个作为新的主数据库。

选举日志

我们可以使用命令查看日志,查看哨兵的选举过程。

docker logs -f redis-sentinel1

在这里插入图片描述

日志解读:

# 主数据库 172.17.0.2 6379 下线了
1:X 26 Jun 2023 13:46:29.680 # +sdown master redis-master 172.17.0.2 6379
1:X 26 Jun 2023 13:46:29.823 # Could not rename tmp config file (Device or resource busy)
1:X 26 Jun 2023 13:46:29.823 # WARNING: Sentinel was not able to save the new configuration on disk!!!: Device or resource busy
1:X 26 Jun 2023 13:46:29.823 # +new-epoch 1
1:X 26 Jun 2023 13:46:29.825 # Could not rename tmp config file (Device or resource busy)
1:X 26 Jun 2023 13:46:29.825 # WARNING: Sentinel was not able to save the new configuration on disk!!!: Device or resource busy
1:X 26 Jun 2023 13:46:29.825 # +vote-for-leader 07a74f95d2f3284e2bcbd34bac98b29e527d5878 1
# 等待了 30000 毫秒之后(注意日志时间),3 个哨兵判断主数据库下线,超过了配置的 2 个哨兵,哨兵主观确定主数据库下线
1:X 26 Jun 2023 13:46:30.842 # +odown master redis-master 172.17.0.2 6379 #quorum 3/2
1:X 26 Jun 2023 13:46:30.842 # Next failover delay: I will not start a failover before Mon Jun 26 13:52:29 2023
1:X 26 Jun 2023 13:46:31.039 # +config-update-from sentinel 07a74f95d2f3284e2bcbd34bac98b29e527d5878 172.17.0.8 26379 @ redis-master 172.17.0.2 6379
# 切换已下线的主数据库 172.17.0.2 6379,选举 172.17.0.5 6379 为新的主数据库
1:X 26 Jun 2023 13:46:31.039 # +switch-master redis-master 172.17.0.2 6379 172.17.0.5 6379
# 重新构建主从关系
1:X 26 Jun 2023 13:46:31.040 * +slave slave 172.17.0.4:6379 172.17.0.4 6379 @ redis-master 172.17.0.5 6379
1:X 26 Jun 2023 13:46:31.040 * +slave slave 172.17.0.3:6379 172.17.0.3 6379 @ redis-master 172.17.0.5 6379
# 重新构建主从关系,原本的主数据库 172.17.0.2 6379 被降为从数据库
1:X 26 Jun 2023 13:46:31.040 * +slave slave 172.17.0.2:6379 172.17.0.2 6379 @ redis-master 172.17.0.5 6379
1:X 26 Jun 2023 13:46:31.044 # Could not rename tmp config file (Device or resource busy)
1:X 26 Jun 2023 13:46:31.044 # WARNING: Sentinel was not able to save the new configuration on disk!!!: Device or resource busy
# 从库 172.17.0.2 6379 下线(但是不影响主库和其他从库和哨兵)
1:X 26 Jun 2023 13:47:01.083 # +sdown slave 172.17.0.2:6379 172.17.0.2 6379 @ redis-master 172.17.0.5 6379

重启主数据库

重新启动原本的主数据库

docker start redis-master

查看原本的主数据的信息:

docker exec -it redis-master bash

redis-cli

info Replication

在这里插入图片描述
我们可以看到原本的主数据在宕机后重新启动,已经彻底变成了从数据库。

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

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

相关文章

Linux学习之grub配置文件介绍

grub配置文件 /etc/default/grub这个文件里边有一些简单的grub配置。 可以看到/etc/default/grub文件里有GRUB_CMDLINE_LINUX"crashkernelauto rhgb quiet idlehalt biosdevname0 net.ifnames0 consoletty0 consolettyS0,115200n8 noibrs nvme_core.io_timeout429496729…

全网独家--【图像色彩增强】方法梳理和问题分析

文章目录 图像增强图像色彩增强问题可视化比较 难点色彩空间大&#xff0c;难以准确表征&#xff1f;不同场景差异大&#xff0c;难以自适应&#xff1f;计算量大&#xff0c;但应用场景往往实时性要求高&#xff1f; 方法传统方法深度学习逐像素预测3D LUT模仿ISP 个人思考批判…

2.数据的类型、数据的输入输出

2.数据的类型、数据的输入输出 2.1 数据类型-常量-变量(整型-浮点-字符)2.1.1 数据类型2.1.2 常量2.1.3 变量2.1.4 整型类型2.1.5 浮点型数据2.1.6 字符型数据字符型常量字符型变量 2.1.7 字符串型常量 2.2 混合运算-printf讲解 2.1 数据类型-常量-变量(整型-浮点-字符) 2.1.1…

shell脚本怎么获取当前脚本名称(获取脚本文件名)$(basename “$0“)(basename命令:去除字符串路径部分、去除后缀)

文章目录 shell脚本如何获取当前执行脚本名称解释&#xff1a;$(basename "$0")$0&#xff08;当前脚本的名称&#xff0c;带脚本与工作目录之间的相对路径&#xff09;basename&#xff08;去除字符串路径部分&#xff09;示例 拓展&#xff1a;basename命令的完整用…

项目引入多个连接池,导致使用其他连接池,maven分析学习

第一步在命令行中执行 mvn dependency:tree > excludeParentstart.log如果你的settings文件不是项目使用的setting配置&#xff0c;那么就使用下面的命令 mvn -gs 你的路径/apache-maven-3.8.2/conf/settings-person.xml dependency:tree > excludeParentstart.log然后…

Spring学习---上篇

文章目录 1、Spring1.1、简介1.2、优点1.3、Spring的组成1.4、拓展 2、IOC理论推导3、IOC的本质3.1、IOC概念3.2、IoC是Spring框架的核心内容 3、HelloSpring3.1、实现3.2、思考 4、IOC创建对象的方式5、Spring配置5.1、别名&#xff08;alias&#xff09;5.2、Bean的配置5.3、…

Multi-class classification without multi-class labels (ICLR 2019)

Multi-class classification without multi-class labels (ICLR 2019) 摘要 这项工作提出了针对多分类的新策略&#xff0c;不需要具体的类别标签&#xff0c;取而代之是利用样本之间的两两相似度&#xff0c;这是一种弱化的标注方式。所提方法称作元分类学习&#xff0c;为两…

ModaHub魔搭社区:向量数据库Milvus使用 MySQL 管理元数据教程

目录 使用 MySQL 管理元数据 常见问题 数据管理相关博客 使用 MySQL 管理元数据 Milvus 默认使用 SQLite 作为元数据后台管理服务&#xff0c;SQLite 内嵌于 Milvus 进程中&#xff0c;无需启动额外服务。但是在生产环境中&#xff0c;基于可靠性的考虑&#xff0c;我们强烈…

【数据库管理】十分钟了解啥是三级封锁协议、X锁和S锁

一.为什么要用锁 在多用户共享系统中&#xff0c;许多事务可能同时对同一数据进行操作&#xff0c;称为“并发操作”&#xff0c;此时数据库管理系统的并发控制子系统负责协调并发事务的执行&#xff0c;保证数据库的完整性不受破坏&#xff0c;同时避免用户得到不正确的数据。…

Spring框架概括

spring是什么&#xff1f; Spring是2003年兴起的&#xff0c;它是一个轻量级的&#xff0c;非侵入式的IOC和AOP的一站式框架&#xff0c;为简化企业级应用开发。 它的特点&#xff1a; 轻量级&#xff1a;指的是核心jar包比较小的。 非侵入式的&#xff1a;框架代码不会侵入…

Java——《面试题——MQ篇》

前文 java——《面试题——基础篇》 Java——《面试题——JVM篇》 Java——《面试题——多线程&并发篇》 Java——《面试题——Spring篇》 Java——《面试题——SpringBoot篇》 Java——《面试题——MySQL篇》​​​​​​ Java——《面试题——SpringCloud》 Java…

KingFusion3.6是什么?

哈喽&#xff0c;大家好&#xff0c;我是雷工&#xff01; 今天继续学习KingFusion3.6&#xff0c;以下为学习笔记。 一、KingFusion3.6简介 1、管控一体化全组态平台KingFusion3.6是一款面向工业企业执行层的生产信息化管理系统。 2、KingFusion3.6基于“全组态”技术&#…

使用ROS功能包camera_calibration进行单目相机和双目相机的内参和外参标定

1.概述 本文总结使用ROS标定单目和双目相机的过程&#xff0c;同时提供生成棋盘格文件的方法。 参考链接&#xff1a; [1]使用ros标定相机的内参和外参 [2]ROS下采用camera_calibration进行双目相机标定 2.生成棋盘格文件 棋盘格可以自己买一个&#xff0c;或者打印一个粘在…

日本团队推出 AI 恋爱游戏:主角穿什么,玩家说了算

女主穿什么&#xff0c;还能由玩家决定&#xff1f;&#xff01; IT之家6月25日消息&#xff0c;来自日本的一个两人团队近期发布了一段视频&#xff0c;展示了一款正在开发中的基于 AI 的恋爱游戏。 在游戏初期&#xff0c;女主角会以黑色剪影的形式出现&#xff0c;针对女主…

紫云谷游记

先说重点&#xff0c;TLNR 1.早点去&#xff0c;方便找地方停车&#xff0c;坐渡船不用排队太久。 2.景区里的饭没外面的好吃。 3.溯溪回来再在游泳池游泳&#xff0c;溯溪凉快&#xff0c;游泳太晒。 4.溯溪真的好爽。 导航&#xff1a; 紫云谷乘船码头停车场 景区介绍就不多说…

常见电池容量概念

嵌入式软件做产品一定要考虑功耗问题 功耗是多少&#xff0c;装上电池能用多久。 1、毫安时和毫瓦时 毫安时&#xff08;mAh&#xff09;和毫瓦时&#xff08;mWh&#xff09;是两个不同的物理量&#xff0c;它们分别表示电量和能量的度量单位。下面图片搜18650得到不同结果&…

Elasticsearch介绍与应用

Elasticsearch介绍与应用 Elasticsearch的官方文档。 Elasticsearch官网参考文档&#xff1a;https://www.elastic.co/guide/index.html Elasticsearch官方下载地址&#xff1a;https://www.elastic.co/cn/downloads/elasticsearch mvnrepository依赖库地址&#xff1a;http…

你对工作队列了解多少?Linux中断处理中的workqueue介绍

Linux中断处理中的workqueue介绍 一、workqueue的作用及在Linux中断处理中的应用1.1、workqueue的概述1.2、workqueue在Linux中断处理中的作用 二、workqueue的实现原理2.1、工作队列和工作者线程的关系2.2、工作队列的创建和销毁2.3、工作者线程的创建和销毁2.4、扩展知识&…

2023年的今天,谨慎进入网络安全行业

前言 2023年的今天&#xff0c;慎重进入网安行业吧&#xff0c;目前来说信息安全方向的就业对于学历的容忍度比软件开发要大得多&#xff0c;还有很多高中被挖过来的大佬。 理由很简单&#xff0c;目前来说&#xff0c;信息安全的圈子人少&#xff0c;985、211院校很多都才建…

低代码没前途?那是你“盲盒”没拆好

创新本质是什么&#xff1f;一是让昂贵的东西变得便宜&#xff0c;老百姓能用&#xff1b;二是高门槛东西变得低门槛&#xff0c;普通人可用。琢磨着&#xff0c;这不就是说低代码吗&#xff1f; 低代码&#xff1a;让人找不到工作&#xff1f; 低代码无疑成为开发业务的一种…