介绍一下redis中底层磁盘及IO模型,数据持久化机制,哨兵机制

底层磁盘及IO模型: Redis中的数据存储在内存中,但为了保证数据的持久化,Redis还提供了两种数据持久化方式:RDB(Redis DataBase)和AOF(Append-Only File)。

  1. RDB:RDB是一种快照的方式,可以手动或自动将数据以二进制的形式保存到硬盘上。当发生持久化时,Redis会fork一个子进程,将内存中的数据写入到临时文件中,然后替换原来的RDB文件。RDB文件存储的是所有数据的快照,可以通过加载RDB文件来恢复数据。

  2. AOF:AOF是一种日志的方式,会将每个写操作追加到一个文件的末尾,以此来记录所有的写操作。当需要恢复数据时,只需重新执行文件中的写操作即可。AOF文件存储的是所有的写操作,可以通过重放AOF文件中的写操作来恢复数据。

Redis的IO模型采用了多路复用技术,主要通过select、poll、epoll函数来实现。当Redis有多个客户端连接时,采用非阻塞IO的方式处理客户端请求,避免了线程创建、销毁的开销,提高了IO的效率。

数据持久化机制: Redis提供了两种数据持久化方式:RDB和AOF。

  1. RDB:RDB是一种快照的方式,可以手动或自动将数据以二进制的形式保存到硬盘上。RDB文件存储的是所有数据的快照,可以通过加载RDB文件来恢复数据。RDB方式适用于备份数据、恢复数据等场景,但可能存在数据丢失的风险。

  2. AOF:AOF是一种日志的方式,会将每个写操作追加到一个文件的末尾,以此来记录所有的写操作。当需要恢复数据时,只需重新执行文件中的写操作即可。AOF方式适用于数据持久化和数据恢复,比RDB方式更安全,但可能导致文件体积较大。

哨兵机制: Redis的哨兵机制用于监控和管理Redis的高可用性。哨兵是一个独立的进程,可以监控多个Redis实例,并在主节点出现故障时自动进行故障转移。

哨兵的工作流程如下:

  1. 哨兵定期向Redis实例发送PING命令,检查实例是否正常工作。
  2. 当哨兵发现主节点不可达时,会进行故障转移。
  3. 哨兵会选出一个从节点作为新的主节点,并将其他从节点切换到新的主节点。
  4. 当主节点重新可用时,哨兵会将其设置为新的从节点,以进行故障恢复。

哨兵机制可以提供Redis的高可用性和故障恢复能力,但仍有可能因为哨兵本身出现故障而导致系统不可用。为了提高可靠性,可以使用多个哨兵节点以提供容错和冗余。

相关推荐
曲幽3 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
知我Deja_Vu5 天前
redisCommonHelper.generateCode(“GROUP“),Redis 生成码方法
数据库·redis·缓存
Charlie_lll5 天前
Redis脑裂问题处理——基于min-replicas-to-write配置
redis·后端
奇点爆破XC5 天前
Redis迁移
数据库·redis·bootstrap
断手当码农5 天前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
菜鸟小九5 天前
redis原理篇(基本数据结构)
数据结构·数据库·redis
没有bug.的程序员5 天前
电商秒杀系统深度进阶:高并发流量建模、库存零超卖内核与 Redis+MQ 闭环
数据库·redis·缓存·高并发·电商秒杀·流量建模·库存零超卖
菜鸟小九5 天前
redis原理篇(五种数据结构)
数据结构·数据库·redis
初次攀爬者5 天前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端
June`5 天前
Redis缓存深度解析:20%数据应对80%请求
数据库·redis