redis缓存的东西,在系统崩溃重启后还能恢复吗?
这个取决于是否开启了持久化功能以及使用的持久化方式,所以了解相关知识并做好准备是极有必要的。redis有两种运行模式:
- 不开启持久化
Redis 的数据只存储在内存中。一旦 Redis 进程重启(无论是手动重启、服务器重启还是进程崩溃),所有数据都会丢失。
- 开启持久化
Redis 提供了两种持久化方式,重启可以恢复数据
2.1 RDB
工作原理: 在指定的时间间隔内,将内存中的数据集快照写入磁盘rdb文件。
恢复方式: 重启时,会自动加载dump.rdb文件,将数据恢复到内存中。
**特点:**性能高(fork 子进程写入,不阻塞主进程),但可能丢失最后一次快照到重启前的数据。
配置方法:
save <seconds> <changes>
当时间和变化同时满足时写入
2.2 AOF
工作原理: 以日志的形式记录 Redis 的每一条写命令(比如set key value),重启时通过重新执行这些命令恢复数据。
恢复方式: 重启会优先加载 AOF 文件(因为 AOF 的数据更完整),恢复所有记录的写操作数据。
**特点:**数据安全性更高(可配置appendfsync always实时写入,或everysec每秒写入),但文件体积可能更大,恢复速度比 RDB 稍慢。
配置方法:
appendonlyyes
appendfsync everysec