图解Redis,Redis主从复制与Redis哨兵机制

大家好,我是哪吒。

上一篇分享了​​离谱!面试为啥都问Redis?赶紧补一下​​,完成了Redis的初体验。

今天分享一下Redis主从复制与Redis哨兵机制相关的知识点,实现快速入门,丰富个人简历,提高面试level,给自己增加一点谈资,秒变面试小达人,BAT不是梦。

一、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复制工作流程

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

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

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

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

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

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

7187:C14Mar22:14:24.106#nzbcRedisisstartingnzbc
7187:C14Mar22:14:24.107#Redisversinotallow=6.0.8, bits=64, commit=00000000, modified=0, pid=7187, juststarted
7187:C14Mar22:14:24.108#Configurationloaded
7188:S14Mar22:14:24.110*Increasedmaximumnumberofopenfilesto10032 (itwasoriginallysetto256).
_._
_.-``__''-._
_.-```. `_. ''-._Redis6.0.8 (00000000/0) 64bit
.-`` .-```. ```\/_.,_''-._
( ' , .-` | `, ) Running in standalone mode
|`-._`-...-`__...-.``-._|'` _.-'|Port: 6380
|`-._`._/_.-' | PID: 7188
`-._`-._`-./_.-' _.-'
|`-._`-._`-.__.-' _.-'_.-'|
|`-._`-.__.-'_.-'|http://redis.io
`-._`-._`-.__.-'_.-'_.-'
|`-._`-._`-.__.-' _.-'_.-'|
|`-._`-.__.-'_.-'|
`-._`-._`-.__.-'_.-'_.-'
`-._`-.__.-' _.-'
`-.__.-'
`-.__.-'

7188:S14Mar22:14:24.120#Serverinitialized
7188:S14Mar22:14:24.114*DBloadedfromdisk: 0.000seconds
7188:S14Mar22:14:24.122*Beforeturningintoaslave, usingmymasterparameterstosynthesizeacachedmaster: Imaybeabletosynchronizewiththenewmasterwithjustapartialtransfer.
7188:S14Mar22:14:24.122*Readytoacceptconnections
7188:S14Mar22:14:24.123*ConnectingtoMASTER127.0.0.1:6379
7188:S14Mar22:14:24.123*MASTER<->SLAVEsyncstarted
7188:S14Mar22:14:24.123*NonblockingconnectforSYNCfiredtheevent.
7188:S14Mar22:14:24.124*MasterrepliedtoPING, replicationcancontinue...
7188:S14Mar22:14:24.124*Tryingapartialresynchronization (request9b3cs5w9g6x3004fa9a0999361035b71ecf70ab4:30783).
7188:S14Mar22:14:24.130*Fullresyncfrommaster: cb4as85df693ad62f09ce4f486e0d43ec8f36334:0
7188:S14Mar22:14:24.130*Discardingpreviouslycachedmasterstate.
7188:S14Mar22:14:24.163*MASTER<->SLAVEsync: receiving5484bytesfrommaster
7188:S14Mar22:14:24.165*MASTER<->SLAVEsync: Flushingolddata
7188:S14Mar22:14:24.165*MASTER<->SLAVEsync: LoadingDBinmemory
7188:S14Mar22:14:24.167*MASTER<->SLAVEsync: Finishedwithsuccess

七、Redis哨兵是什么?

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

1、Redis哨兵的作用

  1. 主从监控,监控主从数据库是否运行正常;
  2. 消息通知,哨兵可以将故障信息发送给客户端;
  3. 故障转移,如果master异常。哨兵会进行主备切换,将其中一个slave转为master;
  4. 配置中心,客户端通过连接哨兵获取Redis服务集群的主节点信息;

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

八、实战演练

1、搭建3个哨兵服务器

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

2、sentinel.conf参数选项说明

bind0.0.0.0
daemonizeyes
protected-modeno
port6391
logfile"/myredis/sentinel1.log"
pidfile/var/run/redis-sentinel6391.pid
dir/myredis
sentinelmonitormymaster127.0.0.163792
sentinelauth-passmymaster123456

设置要监控的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服务器

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

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

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

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

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

十、总结

介绍了Redis复制、Redis复制的工作流程、Redis哨兵、Redis的实战演练、Redis哨兵运行流程和选举原理,文章通俗易懂,值得回味,哈哈。

本文转载自微信公众号「哪吒编程」,可以通过以下二维码关注。转载本文请联系哪吒编程公众号。

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/303109.html<

(0)
管理的头像管理
上一篇2025-05-25 02:46
下一篇 2025-05-25 02:48

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注