Redis Save 与 BGSAVE 的区别
本文内容纲要:
一,save保存数据到磁盘的方式:
RedisSave命令执行一个同步保存操作,将当前Redis实例的所有数据快照(snapshot)以RDB文件的形式保存到硬盘。
语法
redisSave命令基本语法如下:
redis127.0.0.1:6379>SAVE
返回值
保存成功时返回OK。
二,BGSAVE保存数据到磁盘的方式:
BGSAVE命令执行之后立即返回OK,然后Redisfork出一个新子进程,原来的Redis进程(父进程)继续处理客户端请求,而子进程则负责将数据保存到磁盘,然后退出。
客户端可以通过LASTSAVE命令查看相关信息,判断BGSAVE命令是否执行成功。
时间复杂度:
O(N),N为要保存到数据库中的key的数量。
案例:
redis>BGSAVE
Backgroundsavingstarted
三,结论
SAVE保存是阻塞主进程,客户端无法连接redis,等SAVE完成后,主进程才开始工作,客户端可以连接
BGSAVE是fork一个save的子进程,在执行save过程中,不影响主进程,客户端可以正常链接redis,等子进程fork执行save完成后,通知主进程,子进程关闭。很明显BGSAVE方式比较适合线上的维护操作,两种方式的使用一定要了解清楚在谨慎选择。
本文内容总结:
原文链接:https://www.cnblogs.com/rayong/p/6791330.html