antirez
5bfd409b6e
Streams: XDEL command.
2018-04-18 13:12:09 +02:00
antirez
d13ff164bf
Streams: higher level "delete by ID" API for streams.
2018-04-17 17:55:56 +02:00
antirez
852cc013ac
Streams: iterator entry deletion abilities.
2018-04-17 17:18:00 +02:00
charsyam
a152681256
fix memory leak for streamPropagateXCLAIM
2018-03-21 17:41:59 +09:00
antirez
abe3502ea7
CG: propagate XACK by incrementing server.dirty.
...
This should be more than enough, even if in case of partial IDs that are
not found, we send all the IDs to the slave/AOF, but this is definitely
a corner case without bad effects if not some wasted space.
2018-03-20 17:53:45 +01:00
antirez
d28f9eb1b9
CG: Make XINFO Great Again (and more Redis-ish).
...
With XINFO out of the blue I invented a new syntax for commands never
used in Redis in the past... Let's fix it and make it
Great Again!!11one (TM)
2018-03-20 11:52:42 +01:00
antirez
d7cf910a03
CG: Add JUSTID to XCLAIM propagation to reduce CPU usage.
2018-03-20 11:25:49 +01:00
antirez
2f3149e0a0
CG: Fix propagate() arg count in streamPropagateXCLAIM().
2018-03-20 11:13:41 +01:00
antirez
947f75098c
CG: XGROUP CREATE/DELCONUSMER replication.
2018-03-20 11:07:01 +01:00
antirez
378b5761d8
CG: Replication WIP 1: XREADGROUP and XCLAIM propagated as XCLAIM.
2018-03-19 18:02:19 +01:00
antirez
071ef69726
CG: XINFO STREAM.
2018-03-15 12:54:10 +01:00
antirez
d05efa5b3b
CG: XINFO GROUPS + output format changes.
...
XINFO is mainly an observability command that will be used more by
humans than computers, and even when used by computers it will be a very
low traffic command. For this reason the format was changed in order to
have field names. They'll consume some bandwidth and CPU cycles, but in
this context this is much better than having to understand what the
numbers in the output array are.
2018-03-15 12:54:10 +01:00
antirez
c5507af63c
CG: XINFO CONSUMERS implemented.
2018-03-15 12:54:10 +01:00
antirez
7afd470477
Streams: fix XREAD missing check for NULL object.
2018-03-15 12:54:10 +01:00
antirez
5c1f1f43f8
CG: throw an error if XREADGROUP is used without GROUP.
2018-03-15 12:54:10 +01:00
antirez
c0259d6f04
CG: XGROUP DELCONSUMER implemented.
2018-03-15 12:54:10 +01:00
antirez
edd91aeb36
CG: remove stale comment. XREADGROUP is now implemented.
2018-03-15 12:54:10 +01:00
antirez
a372b4c3ec
CG: implement RETRYCOUNT in XCLAIM.
2018-03-15 12:54:10 +01:00
antirez
3d4a904fe9
CG: NACK created by XCLAIM FORCE must be set in global PEL.
2018-03-15 12:54:10 +01:00
antirez
96fad23879
CG: implement XCLAIM FORCE option.
2018-03-15 12:54:10 +01:00
antirez
038488c0c4
CG: XCLAIM now updates the idle time of the message.
2018-03-15 12:54:10 +01:00
antirez
18f8c34d4a
CG: XCLAIM, use minidle and fix array len.
2018-03-15 12:54:10 +01:00
antirez
8348d92e56
CG: remove unused argument from streamReplyWithRangeFromConsumerPEL().
2018-03-15 12:54:10 +01:00
antirez
591e3f031d
Streams: fix error description for XADD when specified ID is small.
2018-03-15 12:54:10 +01:00
antirez
096350cf33
CG: XCLAIM initial draft.
2018-03-15 12:54:10 +01:00
antirez
dfff06af91
CG: More specific duplicated group error.
2018-03-15 12:54:10 +01:00
antirez
84667bff70
CG: RDB loading first implementation.
2018-03-15 12:54:10 +01:00
antirez
ec0faf1bd9
CG: XPENDING should not create consumers and obey to count.
2018-03-15 12:54:10 +01:00
antirez
c0cf16f988
CG: XPENDING with start/stop/count variant implemented.
2018-03-15 12:54:10 +01:00
antirez
af40a25c52
CG: XPENDING without start/stop variant implemented.
2018-03-15 12:54:10 +01:00
antirez
505520ab09
CG: Now XREADGROUP + blocking operations work.
2018-03-15 12:54:10 +01:00
antirez
797d4df6fd
CG: XACK should return zero when nothing is processed.
2018-03-15 12:54:10 +01:00
antirez
c6ec6fb82a
CG: XACK implementation.
2018-03-15 12:54:10 +01:00
antirez
34d41d8aa5
CG: XREADGROUP can fetch data from the consumer PEL.
2018-03-15 12:54:10 +01:00
antirez
68a8dbb256
CG: first draft of streamReplyWithRangeFromConsumerPEL().
2018-03-15 12:54:10 +01:00
antirez
9292fee76f
CG: Fix order of calls in streamReplyWithRange().
...
We need to check if we are going to serve the request via the PEL before
inserting a deferred array len in the client output buffer.
2018-03-15 12:54:10 +01:00
antirez
4a5eaaeb76
CG: creation of NACK entries in PELs.
2018-03-15 12:54:10 +01:00
antirez
4de6308f6e
CG: fix XREADGROUP ">" special ID parsing due to missing "continue".
2018-03-15 12:54:10 +01:00
antirez
5fa401d531
CG: streamCompareID() + group last_id updating.
2018-03-15 12:54:10 +01:00
antirez
6648d60246
CG: consumer lookup + initial streamReplyWithRange() work to supprot CG.
2018-03-15 12:54:10 +01:00
antirez
f7fbc91be3
CG: add & populate group+consumer in the blocking state.
2018-03-15 12:54:10 +01:00
antirez
2cf40e99f2
CG: fix parsing in XREADGROUP and streamLookupCG() NULL check.
2018-03-15 12:54:10 +01:00
antirez
59eb392351
CG: XGROUPREAD group option parsing and groups lookup.
2018-03-15 12:54:10 +01:00
antirez
4e65528940
CG: fix raxFind() retval check in streamCreateCG().
2018-03-15 12:54:10 +01:00
antirez
4925f7773c
CG: data structures design + XGROUP CREATE implementation.
2018-03-15 12:54:10 +01:00
antirez
c277aaf3b4
Stream: update the listpack pointer in streamTrimByLength().
2018-03-01 17:26:02 +01:00
antirez
a135f4f52c
Streams: fix a few type mismatches in t_stream.c.
2017-12-04 11:59:15 +01:00
antirez
620a9086db
Streams: fix lp-count field for non-same-fields entries.
2017-12-01 10:24:25 +01:00
antirez
0c06581bee
Streams: XRANGE REV option -> XREVRANGE command.
2017-12-01 10:24:25 +01:00
antirez
c46aa40cca
Streams: fix reverse iterator discarding of items out of range.
2017-12-01 10:24:25 +01:00