Redis(Remote Dictionary Server)是一个开源的、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。它通常被称为数据结构服务器,因为值(value)可以是 字符串(string)、哈希(Hash)、列表(list)、集合(sets)、有序集合(sorted sets)等类型。
在Redis中,数据持久化可以通过RDB(Redis DataBase)、AOF(Append Only File)和主从复制(Replication)来实现。这些机制可以帮助在Redis崩溃或重启后恢复数据。
RDB(Redis DataBase)
RDB持久化可以在指定的时间间隔内生成数据集的时间点快照(Snapshot)。这是默认的持久化方式。当Redis需要持久化时,它会fork出一个子进程,子进程会将数据写入一个临时文件,当持久化过程完成后,再用这个临时文件替换旧的RDB文件。Redis可以通过配置来自动进行快照持久化,也可以手动通过执行SAVE
或BGSAVE
命令来触发。
RDB恢复过程:
- Redis启动时,如果检测到RDB文件存在,则会优先使用RDB文件进行恢复。
- Redis载入RDB文件,用文件中的数据替换内存中的数据,完成恢复。
AOF(Append Only File)
与RDB不同,AOF持久化记录服务器接收到的所有写操作命令,并在服务器启动时,通过重新执行这些命令来重建数据集。AOF文件中的命令全部以Redis协议的格式来保存,新命令会被追加到文件的末尾。Redis可以通过配置来开启AOF持久化,并设置同步策略。
AOF恢复过程:
- Redis启动时,如果检测到AOF文件存在,并且AOF持久化被开启,则会使用AOF文件进行恢复。
- Redis读取AOF文件,并执行其中的写命令,将数据加载到内存中。
主从复制(Replication)
Redis的主从复制功能允许用户创建多个从服务器(Slave),这些服务器会复制主服务器(Master)上的所有数据,并实时保持更新。主从复制可以实现数据的备份,并且可以用来进行读操作的负载均衡。
主从复制流程:
- 从服务器连接主服务器,并发送
SYNC
命令。 - 主服务器执行
BGSAVE
命令,生成RDB文件,并使用缓冲区记录此后执行的所有写命令。 - 主服务器将RDB文件发送给从服务器,从服务器载入RDB文件,完成数据的初始同步。
- 主服务器将缓冲区中的写命令发送给从服务器,从服务器执行这些命令,保持与主服务器的数据同步。
- 之后,主服务器每次执行写命令时,都会将这些命令发送给从服务器,从服务器执行命令,保持与主服务器的数据一致。
主从复制崩溃恢复:
- 如果主服务器崩溃,从服务器可以继续提供服务,保证数据的可用性。
- 管理员可以将某个从服务器升级为新的主服务器,其他从服务器再复制这个新的主服务器,完成恢复。
在实际使用中,可以结合RDB、AOF和主从复制来提高Redis的可用性和可靠性。例如,可以开启AOF持久化来保证数据的完整性,同时配置主从复制来实现数据的备份和负载均衡。