redis源代码分析 - replication
这篇讲的是Redis主从复制(Replication)机制在源码层面的完整实现。作者从slaveof命令切入,详细拆解了从建立连接到数据同步的全流程。 核心实现思路围绕一系列状态机变迁展开。当slave端收到slaveof命令后,会通过主线程的时间事件发起与master的连接。master收到SYNC指令后,会通过fork子进程进行全量RDB持久化,完成后再将文件发送给slave。slave接收并加载完RDB后,双方便进入基于命令传播的增量同步阶段。整个过程由一系列状态(如REDIS_REPL_CONNECT、REDIS_REPL_TRANSFER、REDIS_REPL_ONLINE等)驱动流转,对应的函数逻辑集中在replication.c中。 文章的巧妙之处在于,作者用流程图和状态图将这个涉及父子进程、多线程事件、文件IO的复杂过程梳理得非常清晰。特别是对master端处理多个slave请求时,如何调度或共享bgsave持久化的几种情况,以及slave端在初始化同步时会暂时阻塞服务这一重要细节,都做了明确说明。这帮助读者快速抓住了Redis复制设计中“先全量、后增量”的核心,以及为保证一致性所付出的代价。