diff --git a/src/replication.c b/src/replication.c index 8090a27a..13a1927a 100644 --- a/src/replication.c +++ b/src/replication.c @@ -376,6 +376,13 @@ void syncWithMaster(aeEventLoop *el, int fd, void *privdata, int mask) { REDIS_NOTUSED(privdata); REDIS_NOTUSED(mask); + /* If this event fired after the user turned the instance into a master + * with SLAVEOF NO ONE we must just return ASAP. */ + if (server.replstate == REDIS_REPL_NONE) { + close(fd); + return; + } + redisLog(REDIS_NOTICE,"Non blocking connect for SYNC fired the event."); /* This event should only be triggered once since it is used to have a * non-blocking connect(2) to the master. It has been triggered when this