Redis持久化主要方式:
1、RDB(Redis DataBase)
- 通过快照(内存中数据在某一时刻的状态记录)的方式实现持久化。
- 根据快照的触发条件,将内存的数据快照写入磁盘,以二进制的压缩文件进行存储。
- 优点:大规模的数据恢复,并且对数据恢复的完整性要求不高时,使用RDB比AOF更高效;以二进制压缩文件的形式存储,占用内存更小;Redis使用bgsave命令进行持久化,基本不会影响主进程,保证了Redis的高性能。
- 缺点:Fork的时候,内存中的数据会被克隆一份,大致2倍的膨胀,需要考虑;在备份周期在一定间隔时间做一次备份,所以如果Redis意外down的话,就会丢失最后一次快照后所有修改。
2、AOF(Append Only File)
- 以独立日志的方式记录每次写的命令,重启时重新执行AOF文件中的命令恢复数据。
- AOF重写机制:当AOF文件的大小达到某个阈值时,会将其中指令进行压缩(如果有对于某个key多次的变更指令,则仅保留最新的数据指令)。
- 优点:由于AOF会记录操作指令,因此保证了数据的完整性。
- 缺点:由于是文本形式写入,因此效率较低。
3、混合持久化方式(Redis 4.0及以后版本)
- Redis 4.0之后新增的方式,结合了RDB和AOF的优点。
- 在写入的时候,先把当前数据以RDB形式写入文件的开头,再将后续的操作命令以AOF的格式存入文件。
- 这样既能保证Redis重启时的速度,又能降低数据丢失的风险。
除了上述三种方式外,还有一种较老的方式是虚拟内存方式,但在现代Redis版本中已较少使用或不再被推荐。同时,也有diskstore方式,但在当前Redis的官方文档和社区中,这种方式并不常见或已被其他方式替代。
总结来说,Redis的持久化方式主要包括RDB、AOF和混合持久化方式,其中混合持久化方式是Redis 4.0及以后版本新增的,结合了RDB和AOF的优点。