redis在从库配置后,有时候会发现从库key的数量要远远小于主库,有可能会导致一些疑惑,数据难道不同步?同步出问题了?
其实并没有问题,rdb在保存到磁盘上的时候,会将过期的key,但是还在内存中的key排除掉,这样从库导入后,会发现key的数量要比主库少。看下代码。
后台save的方法
int rdbSaveBackground(char *filename) {
pid_t childpid;
long long start;
if (server.rdb_child_pid != -1) return REDIS_ERR;
server.dirty_before_bgsave = server.dirty;
server.lastbgsave_try = time(NULL);
start = ustime();
if ((childpid = fork()) == 0) {
int retval;
/* Child */
if (server.ipfd > 0) close(server.ipfd);
if (server.sofd > 0) close(server.sofd);
#fork后,主要是调用了rdbsave
retval = rdbSave(filename);
if (retval == REDIS_OK) {
size_t private_dirty = zmalloc_get_private_dirty();
if (private_dirty) {
redisLog(REDIS_NOTICE,
"RDB: %lu MB o