欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 美食 > redis之RDB持久化过程

redis之RDB持久化过程

2025/2/7 11:35:08 来源:https://blog.csdn.net/Ming13416908424/article/details/145483219  浏览:    关键词:redis之RDB持久化过程

redis的rdb持久化过程
在这里插入图片描述
流程图就想表达两点:
1.主进程会fork一个子进程,子进程共享主进程内存数据(fork其实是复制页表),子进程读取数据并写到新的rdb文件,最后替换旧的rdb文件。

2.在持久化过程中主进程接收到用户写操作,会复制一份数据副本,读写操作在数据副本中进行,因此在配置maxmemory的大小时应该合理,预留足够的物理内存,以免rdb过程有写操作的这种情况而导致内存不足出现异常

redis.conf中rdb持久化机制默认配置

#是否在将rdb文件持久化到磁盘时,进行压缩操作。设置为 "yes" 
#可以提高数据安全性,但可能会降低性能。默认为 "no"。
rdbcompression yes
#rdb文件名
dbfilename rdb_dump.rdb
#rdb持久化,快照可以用一个空字符串参数完全禁用:save “”
#在900秒(15分钟)内,如果有至少1个键被改变,则bgsave进行RDB持久化
#在300秒(5分钟)内,如果有至少10个键被改变,则bgsave进行RDB持久化
#在60秒内,如果有至少10000个键被改变,则bgsave进行RDB持久化
save 900 1          
save 300 10          
save 60 10000      

什么时候会促发rdb持久化

1.手动执行save,bgsave命令的时候
2.redis进程退出之前会进行持久化
3.对key的操作符合redis.conf中配置的促发条件

rdb持久化机制优点

1:rdb文件保存的是二进制数据,在恢复大数据集时速度比aof的快

rdb持久化机制缺点

1.rdb时间比较长,两次rdb之间存在数据丢失风险
2.数据量大时,fork子进程,压缩,写rdb文件耗时都比较长

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com