b38f52169b
Merge pull request #4777 from soloestoy/avoid-double-close
...
anet: avoid double close
2018-03-22 16:22:32 +01:00
3163c9cb63
Merge pull request #4781 from guybe7/block_list_notify
...
Make blocking list commands send keyspace notifications
2018-03-22 16:21:19 +01:00
6c4cb1670a
Add top comments in two addReply*() functions.
2018-03-22 11:45:04 +01:00
b86c26b2fd
Massivily simplify addReply*() functions in networking.c
2018-03-22 11:42:50 +01:00
fa00e20b16
Make blocking list commands send keyspace notifications
2018-03-22 17:22:26 +07:00
5d8c89163c
Merge pull request #4757 from charsyam/feature/fix-invalid-listpack-type-in-makefile
...
fix listpack.c to listpack.o in Makefile
2018-03-22 09:20:17 +01:00
7acf0e0a18
Merge pull request #3826 from charsyam/feature/fix_dlopen_leak
...
fix missed dlclose leak in module.c
2018-03-22 09:19:26 +01:00
da621783f0
Merge pull request #4691 from oranagra/active_defrag_v2
...
Active defrag v2
2018-03-22 09:16:32 +01:00
3851d30ada
Merge pull request #4779 from charsyam/feature/fix-streamPropagateXCLAIM
...
fix memory leak for streamPropagateXCLAIM
2018-03-22 09:02:37 +01:00
71c7477fd4
fix memory leak for streamPropagateXCLAIM
2018-03-21 17:41:59 +09:00
46f767aa19
fix missed call on freeaddrinfo
2018-03-21 15:34:13 +08:00
11baa8487c
anet: avoid double close
2018-03-21 15:13:51 +08:00
233da29f4d
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
0f2c6b6a18
Streams: improve MEMORY USAGE computation, include CGs.
2018-03-20 17:50:40 +01:00
5577130451
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
2ba9a57c9a
CG: Add JUSTID to XCLAIM propagation to reduce CPU usage.
2018-03-20 11:25:49 +01:00
ad716e29c0
CG: Fix propagate() arg count in streamPropagateXCLAIM().
2018-03-20 11:13:41 +01:00
3cae5f0321
CG: XGROUP CREATE/DELCONUSMER replication.
2018-03-20 11:07:01 +01:00
0b58ad301e
CG: Replication WIP 1: XREADGROUP and XCLAIM propagated as XCLAIM.
2018-03-19 18:02:19 +01:00
3c2a952912
Merge branch 'oertl-hyperloglog-improvement' into unstable
2018-03-16 16:58:16 +01:00
36b78e8dfe
Aesthetic changes to PR #4749 .
2018-03-16 16:57:53 +01:00
87cc94864c
Fix HyperLogLog test script for new redis-rb API.
2018-03-16 16:34:04 +01:00
7e3c583532
Merge branch 'hyperloglog-improvement' of https://github.com/oertl/redis into oertl-hyperloglog-improvement
2018-03-16 16:27:38 +01:00
38bc8ea531
RDB version 9.
2018-03-16 13:48:44 +01:00
8b0cfb1e66
RDB: Implement future-proof module AUX data loading.
2018-03-16 13:47:10 +01:00
fd0c4c0277
add rdb-save-incremental-fsync option in redis.conf
2018-03-16 00:48:59 +08:00
54cae05ea7
rdb: incremental fsync when redis saves rdb
2018-03-16 00:44:50 +08:00
b1aae86fc6
RDB: make RDB check aware of LFU/LRU opcodes.
2018-03-15 16:39:33 +01:00
8176a2ee76
RDB: LRU/LFU branches missed continue.
2018-03-15 16:33:18 +01:00
1ce50a7adf
RDB: Ability to load LFU/LRU info.
2018-03-15 16:24:53 +01:00
d7a5c0eb71
RDB: Ability to save LFU/LRU info.
...
This is a big win for caching use cases, since on reloading Redis will
still have some idea about what is worth to evict and what not.
However this only solves part of the problem because the information is
only partially propagated to slaves (on write operations). Reads will
not affect slaves LFU and LRU counters, so after a failover the eviction
decisions are kinda random until keys start to collect some aging/freq info.
However since new slaves are initially populated via RDB file transfer,
this means that if we spin up a new slave from a master, and perform an
immediate manual failover (for instance in order to upgrade the master),
the slave will have eviction informations to use for some time.
The LFU/LRU info is persisted only if the maxmemory policy is set to one
of the relevant type, even if no actual "maxmemory" memory limit is
set.
2018-03-15 13:15:55 +01:00
6614361615
CG: XINFO STREAM.
2018-03-15 12:54:10 +01:00
d7d8cd0b2f
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
0cf6b1e3ae
CG: XINFO CONSUMERS implemented.
2018-03-15 12:54:10 +01:00
67eeeb0b10
Streams: fix XREAD missing check for NULL object.
2018-03-15 12:54:10 +01:00
8d8755c7b5
CG: throw an error if XREADGROUP is used without GROUP.
2018-03-15 12:54:10 +01:00
d4f81ebdba
CG: XGROUP DELCONSUMER implemented.
2018-03-15 12:54:10 +01:00
9b423ae237
CG: remove stale comment. XREADGROUP is now implemented.
2018-03-15 12:54:10 +01:00
e6d434c167
CG: implement RETRYCOUNT in XCLAIM.
2018-03-15 12:54:10 +01:00
f3d9520ccb
CG: fix CG RDB loading not found conditional.
2018-03-15 12:54:10 +01:00
34614a1508
CG: NACK created by XCLAIM FORCE must be set in global PEL.
2018-03-15 12:54:10 +01:00
596264aee9
CG: implement XCLAIM FORCE option.
2018-03-15 12:54:10 +01:00
b26f03bd69
CG: XCLAIM now updates the idle time of the message.
2018-03-15 12:54:10 +01:00
f7d4c3acdf
Streams: trap more errors in stream loading + RDB check type name.
2018-03-15 12:54:10 +01:00
8727b4845b
CG: XCLAIM, use minidle and fix array len.
2018-03-15 12:54:10 +01:00
09e3b3b975
CG: remove unused argument from streamReplyWithRangeFromConsumerPEL().
2018-03-15 12:54:10 +01:00
13ff7bc3ef
CG: fix RDB saving when there are no consumer groups.
2018-03-15 12:54:10 +01:00
267f7f2c97
Streams: fix error description for XADD when specified ID is small.
2018-03-15 12:54:10 +01:00
0a6780e560
CG: XCLAIM initial draft.
2018-03-15 12:54:10 +01:00
00a29b1a81
Make addReplyError...() family functions able to get error codes.
...
Now you can use:
addReplyError("-MYERRORCODE some message");
If the error code is omitted, the behavior is like in the past,
the generic -ERR will be used.
2018-03-15 12:54:10 +01:00