2024-05-02  阅读(60)
版权声明:本文为博主付费文章,严禁任何形式的转载和摘抄,维权必究。 本文链接: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的持久化机制是怎样的?


Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw