iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Redis主从复制与哨兵机制是什么
  • 780
分享到

Redis主从复制与哨兵机制是什么

2023-07-05 18:07:22 780人浏览 独家记忆
摘要

这篇文章主要介绍了Redis主从复制与哨兵机制是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Redis主从复制与哨兵机制是什么文章都会有所收获,下面我们一起来看看吧。一、Redis复制是什么?Redis复

这篇文章主要介绍了Redis主从复制与哨兵机制是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Redis主从复制与哨兵机制是什么文章都会有所收获,下面我们一起来看看吧。

一、Redis复制是什么?

Redis复制就是主从复制,当主服务器数据发生变化时,自动将新的数据同步到从数据库

数据库可以进行读写操作,从数据库一般指用于读操作。

Redis复制可以保证主数据库崩溃时可以进行数据恢复。

二、Redis复制能干嘛?

  1. 读写分离

  2. 容灾恢复

  3. 数据备份

  4. 水平扩容支撑高并发

三、Redis复制的缺点

1、复制延迟

由于所有的写操作都发生在master数据库,然后同步到slave数据库中,所以会有一定的数据延迟,当系统负担过重时,延迟越大,slave机器的增加也会增加数据延迟的时间。

2、master宕机

如果master宕机了,默认情况下不会将salve数据库自动升级为master数据库。

四、乐观复制策略

Redis采用乐观复制策略,容忍一段时间内主从数据库不一致,但保证最终一致性。这个策略保证了性能,在复制的时候,主数据库不会阻塞,可以继续提供服务。

五、Redis复制常用命令

1、info replication

查看节点的主从关系和配置信息。

2、replicaof 主库Ip 主库port

在从数据库的redis.conf中配置。

3、slaveof 主库IP 主库port

在运行期间修改slave节点的信息,如果该数据库已经是其它主数据库的从数据库了,那么它会停止与其的主从关系,转而成为新配置的主库的从数据库。

4、slaveof no one

使当前数据库停止与其它数据库的同步,升级为主数据库。

六、Redis复制工作流程

slave启动成功后,会连接master数据库,发送一个sync命令,同步数据;如果是第一次连接,则会进行一次全量复制,slave自身的数据会被master数据覆盖清除;

master数据库收到sync命令后,通过RDB开始保存快照,同时将所有接收到的用于修改数据库的命令缓存起来,master数据库执行完RDB持久化后,master将RBD文件和所有缓存的命令发送到所有的slave数据库,完成一次数据同步;

slave收到RDB文件和命令缓存后,将其加载到内存中,从而完成复制初始化;

repl-ping-replica-period 10,表示master发出ping包的周期默认是10秒;

完成首次数据全量同步后,master继续将新的收集到的修改命令定期传给slave数据库,完成数据同步;

如果从机重启了,master的backlog中会记录offset,master会将offset后面的数据复制给slave。

7187:C 14 Mar 22:14:24.106 # nzbc Redis is starting nzbc7187:C 14 Mar 22:14:24.107 # Redis version=6.0.8, bits=64, commit=00000000, modified=0, pid=7187, just started7187:C 14 Mar 22:14:24.108 # Configuration loaded7188:S 14 Mar 22:14:24.110 * Increased maximum number of open files to 10032 (it was originally set to 256).                _._           _.-``__ ''-._      _.-``    `.  `_.  ''-._           Redis 6.0.8 (00000000/0) 64 bit  .-`` .-```.  ```\/    _.,_ ''-._ (    '      ,       .-`  | `,    )     Running in standalone mode |`-._`-...-` __...-.``-._|'` _.-'|     Port: 6380 |    `-._   `._    /     _.-'    |     PID: 7188  `-._    `-._  `-./  _.-'    _.-' |`-._`-._    `-.__.-'    _.-'_.-'| |    `-._`-._        _.-'_.-'    |           Http://redis.io  `-._    `-._`-.__.-'_.-'    _.-' |`-._`-._    `-.__.-'    _.-'_.-'| |    `-._`-._        _.-'_.-'    |  `-._    `-._`-.__.-'_.-'    _.-'      `-._    `-.__.-'    _.-'          `-._        _.-'              `-.__.-'7188:S 14 Mar 22:14:24.120 # Server initialized7188:S 14 Mar 22:14:24.114 * DB loaded from disk: 0.000 seconds7188:S 14 Mar 22:14:24.122 * Before turning into a slave, using my master parameters to synthesize a cached master: I may be able to synchronize with the new master with just a partial transfer.7188:S 14 Mar 22:14:24.122 * Ready to accept connections7188:S 14 Mar 22:14:24.123 * Connecting to MASTER 127.0.0.1:63797188:S 14 Mar 22:14:24.123 * MASTER <-> SLAVE sync started7188:S 14 Mar 22:14:24.123 * Non blocking connect for SYNC fired the event.7188:S 14 Mar 22:14:24.124 * Master replied to PING, replication can continue...7188:S 14 Mar 22:14:24.124 * Trying a partial resynchronization (request 9b3cs5w9g6x3004fa9a0999361035b71ecf70ab4:30783).7188:S 14 Mar 22:14:24.130 * Full resync from master: cb4as85df693ad62f09ce4f486e0d43ec8f36334:07188:S 14 Mar 22:14:24.130 * Discarding previously cached master state.7188:S 14 Mar 22:14:24.163 * MASTER <-> SLAVE sync: receiving 5484 bytes from master7188:S 14 Mar 22:14:24.165 * MASTER <-> SLAVE sync: Flushing old data7188:S 14 Mar 22:14:24.165 * MASTER <-> SLAVE sync: Loading DB in memory7188:S 14 Mar 22:14:24.167 * MASTER <-> SLAVE sync: Finished with success

七、Redis哨兵是什么?

Redis提供了哨兵sentinel机制来监控Redis的性能,如果主数据库宕机了,根据投票数自动将某一个从数据库提升为主数据库,继续对外提供服务。

1、Redis哨兵的作用

  1. 主从监控,监控主从数据库是否运行正常;

  2. 消息通知,哨兵可以将故障信息发送给客户端;

  3. 故障转移,如果master异常。哨兵会进行主备切换,将其中一个slave转为master;

  4. 配置中心,客户端通过连接哨兵获取Redis服务集群的主节点信息;

2、使用哨兵的注意事项:

Redis主从复制与哨兵机制是什么

八、实战演练

1、搭建3个哨兵服务器

监控Redis主从服务器,不存放数据。

Redis主从复制与哨兵机制是什么

2、sentinel.conf参数选项说明

bind 0.0.0.0daemonize yesprotected-mode noport 6391logfile "/myredis/sentinel1.log"pidfile /var/run/redis-sentinel6391.piddir /myredissentinel monitor mymaster 127.0.0.1 6379 2sentinel auth-pass mymaster 123456

Redis主从复制与哨兵机制是什么

设置要监控的master服务器,quorum表示至少有几个哨兵认为客观下线,同意故障转移的法定票数,因此哨兵服务器一般为奇数个。

sentinel monitor <master-name> 127.0.0.1 6379 <quorum>

master服务器设置了密码:

sentinel auth-pass <master-name> <passWord>

通过命令,完成哨兵sentinel的启动,两种方式,任选其一:

  1. redis-sentinel /path/to/sentinel.conf

  2. redis-server /path/to/sentinel.conf --sentinel

九、哨兵运行流程和选举原理

当一个主从配置中的master失效后,sentinel会选举出一个新的master用于接替原master的工作,其它slave服务器自动指向新master,实现数据同步。

1、主观下线

指定多少毫秒之后,主节点没有应答哨兵,此时哨兵会主观上认为主节点已经下线。

sentinel down-after-millisecnds <master-name> <millisecnds>

2、客观下线

多个哨兵sentinel进行投票,根据投票结果才能确认一个master客观上已经宕机。

3、选举master三步走:

(1)先选出一个master服务器

Redis主从复制与哨兵机制是什么

当master数据库宕机后,各个哨兵sentinel节点会进行协商,先通过Raft算法选举出一个领导者哨兵节点,再由领导者进行master的选举。

根据Redis.conf中,优先级slave-priority或者replica-priority最高的从节点(数字越小优先级越高)。复制偏移位置offset最大的从节点;最小Run ID的从节点

(2)其它slave服务器连接到master服务器

执行slaveof no one命令会选举出新的master,并通过slaveof命令将其它从节点成为新master服务器的从节点。

(3)如果旧master服务器恢复正常了,也要成为新master服务器的slave从服务器。

关于“Redis主从复制与哨兵机制是什么”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Redis主从复制与哨兵机制是什么”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: Redis主从复制与哨兵机制是什么

本文链接: https://www.lsjlt.com/news/354500.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis主从复制与哨兵机制是什么
    这篇文章主要介绍了Redis主从复制与哨兵机制是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Redis主从复制与哨兵机制是什么文章都会有所收获,下面我们一起来看看吧。一、Redis复制是什么?Redis复...
    99+
    2023-07-05
  • 图解Redis,Redis主从复制与Redis哨兵机制
    目录 专栏导读一、Redis复制是什么?二、Redis复制能干嘛?三、Redis复制的缺点1、复制延迟2、master宕机 四、乐观复制策略五、Redis复制常用命令1、info re...
    99+
    2023-09-06
    redis java 数据库 分布式
  • redis中主从复制、哨兵、集群的原理是什么
    这篇文章主要介绍了redis中主从复制、哨兵、集群的原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇redis中主从复制、哨兵、集群的原理是什么文章都会有所收获,下面我...
    99+
    2024-04-02
  • Redis6主从复制及哨兵机制的实现
    目录Redis 主从复制什么是主从复制主从配置主Redis配置从Redis配置实现原理Redis 哨兵机制简介哨兵进程的作用故障判定原理分析自动故障迁移案例演示Redis 主从复制 ...
    99+
    2024-04-02
  • Redis中主从复制、哨兵、集群的示例分析
    这篇文章将为大家详细讲解有关Redis中主从复制、哨兵、集群的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、Redis 主从复制1. 主从复制的概述主从复制,...
    99+
    2024-04-02
  • redis主从复制、哨兵和集群的示例分析
    这篇文章主要介绍了redis主从复制、哨兵和集群的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、主从复制1. 主从同步的用处  ...
    99+
    2024-04-02
  • Redis中主从复制和哨兵模式的示例分析
    这篇文章给大家分享的是有关Redis中主从复制和哨兵模式的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。主从复制指的是把一台Redis服务器的数据复制到其他Redis服务...
    99+
    2024-04-02
  • Redis哨兵机制及配置实现
    目录一、为什么 Redis 集群中要有哨兵机制二、模拟主机挂掉之后,人工切换三、哨兵机制的原理四、哨兵机制的实现一、为什么 Redis 集群中要有哨兵机制 Redis 主从复制有一个...
    99+
    2024-04-02
  • redis主从复制是什么
    Redis主从复制是一种数据同步机制,其中一个Redis实例(称为主节点)将其数据异步复制到其他一个或多个Redis实例(称为从节点...
    99+
    2023-09-09
    redis
  • Redis中的主从同步和哨兵模式是什么
    本篇内容主要讲解“Redis中的主从同步和哨兵模式是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Redis中的主从同步和哨兵模式是什么”吧!主从同步主从同...
    99+
    2024-04-02
  • Redis超详细讲解高可用主从复制基础与哨兵模式方案
    目录高可用基础---主从复制主从复制的原理主从复制配置示例1、创建Redis实例2、连接数据库并设置主从复制高可用方案---哨兵模式sentinel哨兵模式简介哨兵工作原理哨兵故障修...
    99+
    2024-04-02
  • Redis的持久化和主从复制机制是什么
    小编给大家分享一下Redis的持久化和主从复制机制是什么,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!Redis持久化Redis 提供了多种不同级别的持久化方式:RDB 持久化可以在指定的时间...
    99+
    2024-04-02
  • Couchbase主从复制机制是什么
    Couchbase的主从复制机制是一种用于在分布式数据库集群中实现数据复制和数据同步的技术。在Couchbase中,主从复制机制由两...
    99+
    2024-04-09
    Couchbase
  • redis主从哨兵模式怎么实现一主二从
    这篇文章主要介绍“redis主从哨兵模式怎么实现一主二从”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“redis主从哨兵模式怎么实现一主二从”文章能帮助大家解决问题。一、环境操作系统:centos7...
    99+
    2023-07-02
  • Redis主从复制和哨兵架构图,集成Spring Boot项目实战分享
    目录 1. Redis 主从复制 2. Redis 哨兵架构 3. 集成spring boot项目案列 Redis 主从复制和哨兵架构是 Redis 集群的重要组成部分,用于提高...
    99+
    2023-08-31
    redis spring boot bootstrap
  • Redis哨兵模式是什么
    这篇文章主要讲解了“Redis哨兵模式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis哨兵模式是什么”吧!哨兵模式1. 哨兵概念在一主多从结构...
    99+
    2024-04-02
  • Redis中的主从复制是什么
    这篇文章主要为大家展示了“Redis中的主从复制是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Redis中的主从复制是什么”这篇文章吧。Redis支持主从...
    99+
    2024-04-02
  • Redis主从复制原理是什么
    Redis主从复制原理是什么?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!一、什么是Redis主从复制?主从复制就是现在有...
    99+
    2024-04-02
  • Redis哨兵原理是什么
    Redis哨兵原理是什么?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!本文实现环境centos7.3 redis4.0re...
    99+
    2024-04-02
  • springboot集成redis哨兵主从怎么实现
    这篇文章主要介绍“springboot集成redis哨兵主从怎么实现”,在日常操作中,相信很多人在springboot集成redis哨兵主从怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”springb...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作