回答
Redis 在持久化时有如下几种情况会阻塞 Redis 服务器。
- 执行
SAVE
命令:当我们手动执行SAVE
命令时,Redis 会阻塞所有其他客户端的请求直到 RDB 快照文件创建完毕。 - 执行
BGSAVE
命令:虽然BGSAVE
是在一个子进程中进行的,在创建 RDB 快照文件过程中,主进程依然可以继续响应客户端请求。但是在执行BGSAVE
命令后,主进程需要进行一次fork()
操作,fork()
操作在内存资源紧张或者数据集较大的情况下可能非常耗时,这期间主进程会被短暂阻塞。 - 重写 AOF 文件:与
BGSAVE
命令一样,重写 AOF 文件(BGREWRITEAOF
)也是发生在 fork 子进程过程中。 - 配置
always
同步策略:在 always 同步策略的模式下,Redis 的每个写命令都会被同步写入到磁盘中,写命令的响应时间会因为磁盘 I/O 速度受限而增加,从而导致阻塞。
关于 Redis 的持久化请阅读:Redis的持久化机制是怎样的?