mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 08:38:27 -05:00
Streams: propagate original MAXLEN argument in XADD context
If we rewrite the MAXLEN argument as zero when no trimming was performed, date between master and slave and aof will be inconsistent, because `xtrim maxlen 0` means delete all entries in stream.
This commit is contained in:
parent
2f2987ffc5
commit
20c6a7fe2c
@ -1186,18 +1186,9 @@ void xaddCommand(client *c) {
|
|||||||
notifyKeyspaceEvent(NOTIFY_STREAM,"xadd",c->argv[1],c->db->id);
|
notifyKeyspaceEvent(NOTIFY_STREAM,"xadd",c->argv[1],c->db->id);
|
||||||
server.dirty++;
|
server.dirty++;
|
||||||
|
|
||||||
/* Remove older elements if MAXLEN was specified. */
|
/* Notify xtrim event if needed. */
|
||||||
if (maxlen >= 0) {
|
if (maxlen >= 0 && streamTrimByLength(s,maxlen,approx_maxlen)) {
|
||||||
if (!streamTrimByLength(s,maxlen,approx_maxlen)) {
|
notifyKeyspaceEvent(NOTIFY_STREAM,"xtrim",c->argv[1],c->db->id);
|
||||||
/* If no trimming was performed, for instance because approximated
|
|
||||||
* trimming length was specified, rewrite the MAXLEN argument
|
|
||||||
* as zero, so that the command is propagated without trimming. */
|
|
||||||
robj *zeroobj = createStringObjectFromLongLong(0);
|
|
||||||
rewriteClientCommandArgument(c,maxlen_arg_idx,zeroobj);
|
|
||||||
decrRefCount(zeroobj);
|
|
||||||
} else {
|
|
||||||
notifyKeyspaceEvent(NOTIFY_STREAM,"xtrim",c->argv[1],c->db->id);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Let's rewrite the ID argument with the one actually generated for
|
/* Let's rewrite the ID argument with the one actually generated for
|
||||||
|
Loading…
Reference in New Issue
Block a user