回答
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