2024-05-02
版权声明:本文为博主付费文章,严禁任何形式的转载和摘抄,维权必究。 本文链接:https://www.skjava.com/mianshi/baodian/detail/1980105376

回答

Redis 在持久化时有如下几种情况会阻塞 Redis 服务器。

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

关于 Redis 的持久化请阅读:Redis的持久化机制是怎样的?