1,RDB持久化(默认)
RDB:快照形式,存储数据结果
1)redis是内存数据库,数据库的状态(非空数据库和K-V)在内存中,如果不持久化到磁盘则进程一旦退出,丢失了数据库的状态。
2)redis中有两个命令能生成RDB文件(二进制
)。save命令会阻塞redis进程;bgsave会使用子进程处理,不会阻塞。
3)DB loaded from disk
redis启动,检测到有RDB文件,则会自动载入(未开启AOF时
)。
4)redis配置文件中save选项,自动触发bgsave将数据持久化到磁盘上。
save 900 1满足900s有一次修改
save 300 10满足300s有10次修改
save 60 10000满足60s有10000次修改
如果只是使用redis缓存,而不需要持久化。可以注释掉save或者使用save ""
2,AOF持久化
AOF:日志形式,存储操作过程
1)Append only file。通过保存redis进程的写命令记录数据库的状态。
2)append将写命令追加到aof_buff缓冲区
文件写入 与同步将aop缓冲区内容写入到AOF文件中
3)appendonly yes开启AOF持久化
appendfilename "appendonly.aof"指定持久化文件
appendfsync everysec持久化策略,每秒
4)AOF文件会越来越大,提供AOF重写,通过读取数据库中的K-V来实现的。
5)appendfsync的值决定aof的效率和安全性。
always:每次时间循环都将aof_buf中内容写入并同步到aof文件。(最多只会丢失一个时间循环。)
everysec:每个事件循环,都将缓冲区内容写入aof文件,每秒进行aof文件同步。(最多丢失1s的数据)
no:每个事件循环都将aof_buf中内容写入aof文件,何时同步由os决定。
6)写入和同步:os先将数据写入到一个内存缓冲区,当满了或者时间到了,才同步到磁盘。
3,RDB和AOF对比
1)RDB可能会造成部分数据的丢失。但是数据体积小。
2)AOF能记录所有写操作,不会丢失数据。数据体积大。