save
Reids save命令执行一个同步保存操作,将当前Redis实例的所有数据快照(snapshort)已RDB文件的方式保存到磁盘
bgsave
bgsave执行后,会立刻返回OK,Redis 会fork一个子进程,原来的redis主进程继续执行后续操作,新fork的子进程负责将数据保存到磁盘,然后退出
区别:
- save同步阻塞主进程,只有等save完后成,才能进行新操作
- basave 是fork的子进程,非阻塞,等执行完后会通知主进程,然后关闭子进程
save m n 触发机制
- 描述:当m秒后 或者 n次请求后,触发保存,配置可以有多个
save 100 10
save 50 20
多个配置,任意一个满足,即可触发同步保存 - 实现原理:通过serverCron函数、dirty计数器和lastsave时间戳,serverCron是redis服务器的周期性操作函数,默认每隔100ms执行一次
网友评论