WAITAOF
WAITAOF numlocal numreplicas timeout
- Available since:
- 7.2.0
- Time complexity:
- O(1)
- ACL categories:
-
@slow
,@connection
,
This command blocks the current client until all previous write commands by that client are acknowledged as having been fsynced to the AOF of the local Redis and/or at least the specified number of replicas. If the timeout, specified in milliseconds, is reached, the command returns even if the specified number of acknowledgments has not been met.
The command will always return the number of masters and replicas that have fsynced all write commands sent by the current client before the WAITAOF
command, both in the case where the specified thresholds were met, and when the timeout is reached.
A few remarks:
- When
WAITAOF
returns, all the previous write commands sent in the context of the current connection are guaranteed to be fsynced to the AOF of at least the number of masters and replicas returned byWAITAOF
. - If the command is sent as part of a
MULTI
transaction (or any other context that does not allow blocking, such as inside scripts), the command does not block but instead returns immediately the number of masters and replicas that fsynced all previous write commands. - A timeout of 0 means to block forever.
- Since
WAITAOF
returns the number of fsyncs completed both in case of success and timeout, the client should check that the returned values are equal or greater than the persistence level required. WAITAOF
cannot be used on replica instances, and thenumlocal
argument cannot be non-zero if the local Redis does not have AOF enabled.
Limitations
It is possible to write a module or Lua script that propagate writes to the AOF but not the replication stream.
(For modules, this is done using the fmt
argument to RedisModule_Call
or RedisModule_Replicate
; For Lua scripts, this is achieved using redis.set_repl
.)
These features are incompatible with the WAITAOF
command as it is currently implemented, and using them in combination may result in incorrect behavior.
Consistency and WAITAOF
Note that, similarly to WAIT
, WAITAOF
does not make Redis a strongly-consistent store.
Unless waiting for all members of a cluster to fsync writes to disk, data can still be lost during a failover or a Redis restart.
However, WAITAOF
does improve real-world data safety.
Implementation details
Since Redis 7.2, Redis tracks and increments the replication offset even when no replicas are configured (as long as AOF exists).
In addition, Redis replicas asynchronously ping their master with two replication offsets: the offset they have processed in the replication stream, and the offset they have fsynced to their AOF.
Redis remembers, for each client, the replication offset of the produced replication stream when the last write command was executed in the context of that client.
When WAITAOF
is called, Redis checks if the local Redis and/or the specified number of replicas have confirmed fsyncing this offset or a greater one to their AOF.
Examples
> SET foo bar
OK
> WAITAOF 1 0 0
1) (integer) 1
2) (integer) 0
> WAITAOF 0 1 1000
1) (integer) 1
2) (integer) 0
In the above example, the first call to WAITAOF
does not use a timeout and asks for the write to be fsynced to the local Redis only; it returns with [1, 0] when this is completed.
In the second attempt we instead specify a timeout, and ask for the write to be confirmed as fsynced by a single replica.
Since there are no connected replicas, the WAITAOF
command unblocks after one second and again returns [1, 0], indicating the write has been fsynced on the local Redis but no replicas.
RESP2/RESP3 Reply
Array reply: The command returns an array of two integers:
- The first is the number of local Redises (0 or 1) that have fsynced to AOF all writes performed in the context of the current connection
- The second is the number of replicas that have acknowledged doing the same.