diff options
author | antirez <antirez@gmail.com> | 2017-11-23 13:05:00 +0100 |
---|---|---|
committer | antirez <antirez@gmail.com> | 2017-11-23 15:14:17 +0100 |
commit | de914ede9385c2886770ac462564be1a659b56aa (patch) | |
tree | b85310330441baf7d0754a02a2bb777540461040 /src | |
parent | ada206559db76b2103c446c2691cb06fbc8c5d31 (diff) | |
download | redis-de914ede9385c2886770ac462564be1a659b56aa.tar.gz |
Modules: fix for scripting replication of modules commands.
See issue #4466 / #4467.
Diffstat (limited to 'src')
-rw-r--r-- | src/module.c | 11 | ||||
-rw-r--r-- | src/server.c | 5 |
2 files changed, 9 insertions, 7 deletions
diff --git a/src/module.c b/src/module.c index 03857ee44..83249554e 100644 --- a/src/module.c +++ b/src/module.c @@ -442,9 +442,7 @@ void moduleFreeContext(RedisModuleCtx *ctx) { void moduleHandlePropagationAfterCommandCallback(RedisModuleCtx *ctx) { client *c = ctx->client; - /* We don't want any automatic propagation here since in modules we handle - * replication / AOF propagation in explicit ways. */ - preventCommandPropagation(c); + if (c->flags & CLIENT_LUA) return; /* Handle the replication of the final EXEC, since whatever a command * emits is always wrappered around MULTI/EXEC. */ @@ -1164,8 +1162,9 @@ int RM_ReplyWithDouble(RedisModuleCtx *ctx, double d) { * in the context of a command execution. EXEC will be handled by the * RedisModuleCommandDispatcher() function. */ void moduleReplicateMultiIfNeeded(RedisModuleCtx *ctx) { - /* Skip this if client explicitly wrap the command with MULTI */ - if (ctx->client->flags & CLIENT_MULTI) return; + /* Skip this if client explicitly wrap the command with MULTI, or if + * the module command was called by a script. */ + if (ctx->client->flags & (CLIENT_MULTI|CLIENT_LUA)) return; /* If we already emitted MULTI return ASAP. */ if (ctx->flags & REDISMODULE_CTX_MULTI_EMITTED) return; /* If this is a thread safe context, we do not want to wrap commands @@ -1218,6 +1217,7 @@ int RM_Replicate(RedisModuleCtx *ctx, const char *cmdname, const char *fmt, ...) /* Release the argv. */ for (j = 0; j < argc; j++) decrRefCount(argv[j]); zfree(argv); + server.dirty++; return REDISMODULE_OK; } @@ -1236,6 +1236,7 @@ int RM_ReplicateVerbatim(RedisModuleCtx *ctx) { alsoPropagate(ctx->client->cmd,ctx->client->db->id, ctx->client->argv,ctx->client->argc, PROPAGATE_AOF|PROPAGATE_REPL); + server.dirty++; return REDISMODULE_OK; } diff --git a/src/server.c b/src/server.c index c9972115a..69dca456e 100644 --- a/src/server.c +++ b/src/server.c @@ -2265,8 +2265,9 @@ void call(client *c, int flags) { propagate_flags &= ~PROPAGATE_AOF; /* Call propagate() only if at least one of AOF / replication - * propagation is needed. */ - if (propagate_flags != PROPAGATE_NONE) + * propagation is needed. Note that modules commands handle replication + * in an explicit way, so we never replicate them automatically. */ + if (propagate_flags != PROPAGATE_NONE && !(c->cmd->flags & CMD_MODULE)) propagate(c->cmd,c->db->id,c->argv,c->argc,propagate_flags); } |