Redis 6.0 release notes ======================= -------------------------------------------------------------------------------- Upgrade urgency levels: LOW: No need to upgrade unless there are new features you want to use. MODERATE: Program an upgrade of the server, but it's not urgent. HIGH: There is a critical bug that may affect a subset of users. Upgrade! CRITICAL: There is a critical bug affecting MOST USERS. Upgrade ASAP. SECURITY: There are security fixes in the release. -------------------------------------------------------------------------------- ================================================================================ Redis 6.0-rc4 Released Thu Apr 16 16:10:35 CEST 2020 ================================================================================ Upgrade urgency LOW: If you are using RC3 without issues, don't rush. Hi all, this the latest release candidate of Redis 6. This is likely to be very similar to what you'll see in Redis 6 GA. Please test it and report any issue :-) Main changes in this release: * Big INFO speedup when using a lot of of clients. * Big speedup on all the blocking commands: now blocking on the same key is O(1) instead of being O(N). * Stale replicas now allow MULTI/EXEC. * New command: LCS (Longest Common Subsequence). * Add a new configuration to make DEL like UNLINK. * RDB loading speedup. * Many bugs fixed (see the commit messages at the end of this node) See you in 14 days for Redis 6 GA. List of commits: antirez in commit 9f594e243: Update SDS to latest version. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 48781dd95: RESP3: fix HELLO map len in Sentinel mode. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 371ab0cff: Don't allow empty spaces in ACL usernames. 1 file changed, 36 insertions(+), 8 deletions(-) antirez in commit b86140ac5: Don't allow empty spaces in ACL key patterns. 1 file changed, 12 insertions(+), 1 deletion(-) liumiuyong in commit a7ee3c3e7: FIX: truncate max/min longitude,latitude related geo_point (ex: {180, 85.05112878} ) 1 file changed, 4 insertions(+) Guy Benoish in commit e5b9eb817: Typo in getTimeoutFromObjectOrReply's error reply 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 0f31bb5c1: Fix HELLO reply in Sentinel mode, see #6160. 1 file changed, 1 insertion(+), 1 deletion(-) hwware in commit b92d9a895: fix spelling in acl.c 1 file changed, 2 insertions(+), 2 deletions(-) antirez in commit 8f896e57a: Fix zsetAdd() top comment spelling. 1 file changed, 3 insertions(+), 3 deletions(-) hayleeliu in commit 8f5157058: fix spelling mistake in bitops.c 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit ddeda9ceb: Fix function names in zslDeleteNode() top comment. 1 file changed, 2 insertions(+), 1 deletion(-) antirez in commit bde1f0a8e: RESP3: change streams items from maps to arrays. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit bec68bff2: Use the special static refcount for stack objects. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 0f239e51b: RDB: refactor some RDB loading code into dbAddRDBLoad(). 3 files changed, 22 insertions(+), 4 deletions(-) antirez in commit f855db61b: incrRefCount(): abort on statically allocated object. 2 files changed, 12 insertions(+), 2 deletions(-) antirez in commit 23094ba01: More powerful DEBUG RELOAD. 3 files changed, 55 insertions(+), 16 deletions(-) antirez in commit 8161a7a3e: RDB: clarify a condition in rdbLoadRio(). 2 files changed, 9 insertions(+), 2 deletions(-) antirez in commit 61b153073: RDB: load files faster avoiding useless free+realloc. 7 files changed, 40 insertions(+), 28 deletions(-) antirez in commit 414debfd0: Speedup: unblock clients on keys in O(1). 4 files changed, 50 insertions(+), 23 deletions(-) antirez in commit cbcd07777: Fix ACL HELP table missing comma. 1 file changed, 12 insertions(+), 12 deletions(-) mymilkbottles in commit 2437455f2: Judge the log level in advance 1 file changed, 1 insertion(+) antirez in commit 35c64b898: Speedup INFO by counting client memory incrementally. 4 files changed, 52 insertions(+), 26 deletions(-) qetu3790 in commit c3ac71748: fix comments about RESIZE DB opcode in rdb.c 1 file changed, 1 insertion(+), 4 deletions(-) antirez in commit c8dbcff9d: Clarify redis.conf comment about lazyfree-lazy-user-del. 1 file changed, 9 insertions(+), 5 deletions(-) zhaozhao.zz in commit abd5156f2: lazyfree: add a new configuration lazyfree-lazy-user-del 4 files changed, 7 insertions(+), 2 deletions(-) antirez in commit 5719b3054: LCS: more tests. 1 file changed, 8 insertions(+) antirez in commit c89e1f293: LCS: allow KEYS / STRINGS to be anywhere. 1 file changed, 6 deletions(-) antirez in commit 0b16f8d44: LCS tests. 1 file changed, 22 insertions(+) antirez in commit 9254a805d: LCS: get rid of STOREIDX option. Fix get keys helper. 2 files changed, 20 insertions(+), 21 deletions(-) antirez in commit a4c490703: LCS: fix stale comment. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit cb92c23de: LCS: output LCS len as well in IDX mode. 1 file changed, 6 insertions(+), 1 deletion(-) antirez in commit 56a52e804: LCS: MINMATCHLEN and WITHMATCHLEN options. 1 file changed, 24 insertions(+), 11 deletions(-) antirez in commit ebb09a5c3: LCS: 7x speedup by accessing the array with better locality. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit a9f8a8cba: LCS: implement KEYS option. 1 file changed, 18 insertions(+), 2 deletions(-) antirez in commit 4aa24e62a: LCS: other fixes to range emission. 1 file changed, 20 insertions(+), 16 deletions(-) antirez in commit 2b67b6b87: LCS: fix emission of last range starting at index 0. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 420aac727: LCS: implement range indexes option. 1 file changed, 59 insertions(+), 9 deletions(-) antirez in commit a518a9a76: LCS: initial functionality implemented. 4 files changed, 156 insertions(+), 1 deletion(-) srzhao in commit 026cc11b0: Check OOM at script start to get stable lua OOM state. 3 files changed, 11 insertions(+), 4 deletions(-) Oran Agra in commit 02b594f6a: diffrent fix for runtest --host --port 2 files changed, 13 insertions(+), 13 deletions(-) Guy Benoish in commit f695d1830: Try to fix time-sensitive tests in blockonkey.tcl 1 file changed, 54 insertions(+), 1 deletion(-) Guy Benoish in commit 0e42cfc36: Use __attribute__ only if __GNUC__ is defined 1 file changed, 12 insertions(+), 3 deletions(-) Guy Benoish in commit 91ed9b3c4: Modules: Perform printf-like format checks in variadic API 1 file changed, 3 insertions(+), 3 deletions(-) Valentino Geron in commit 3e0d20962: XREAD and XREADGROUP should not be allowed from scripts when BLOCK option is being used 3 files changed, 18 insertions(+), 2 deletions(-) Guy Benoish in commit 240094c9b: Stale replica should allow MULTI/EXEC 1 file changed, 3 insertions(+), 3 deletions(-) Xudong Zhang in commit 209f3a1eb: fix integer overflow 1 file changed, 2 insertions(+), 2 deletions(-) Guy Benoish in commit 024c380b9: Fix no-negative-zero test 1 file changed, 1 insertion(+) Oran Agra in commit a38ff404b: modules don't signalModifiedKey in setKey() since that's done (optionally) in RM_CloseKey 4 files changed, 8 insertions(+), 8 deletions(-) Oran Agra in commit 814874d68: change CI to build and run the module api tests 1 file changed, 2 insertions(+) Oran Agra in commit 061616c1b: fix possible warning on incomplete struct init 1 file changed, 1 insertion(+), 1 deletion(-) Guy Benoish in commit 7764996be: Make sure Redis does not reply with negative zero 2 files changed, 10 insertions(+) Guy Benoish in commit eba28e2ce: DEBUG OBJECT should pass keyname to module when loading 3 files changed, 4 insertions(+), 4 deletions(-) David Carlier in commit 15c9e79a7: debug, dump registers on arm too. 1 file changed, 55 insertions(+), 27 deletions(-) hwware in commit cd2b5df97: fix spelling in cluster.c 1 file changed, 1 insertion(+), 1 deletion(-) Valentino Geron in commit 8cdc153f5: XACK should be executed in a "all or nothing" fashion. 2 files changed, 23 insertions(+), 1 deletion(-) hwware in commit b35407fa7: add check for not switching between optin optout mode directly 1 file changed, 12 insertions(+), 1 deletion(-) hwware in commit 4395889c9: add check for not providing both optin optout flag 1 file changed, 8 insertions(+) Guy Benoish in commit 1907e0f18: PERSIST should notify a keyspace event 1 file changed, 1 insertion(+) Guy Benoish in commit c35a53169: streamReplyWithRange: Redundant XSETIDs to replica 1 file changed, 2 insertions(+), 1 deletion(-) antirez in commit 6fe66e096: Simplify comment in moduleTryServeClientBlockedOnKey(). 1 file changed, 3 insertions(+), 12 deletions(-) Guy Benoish in commit 193fc241c: Fix memory corruption in moduleHandleBlockedClients 3 files changed, 149 insertions(+), 46 deletions(-) ================================================================================ Redis 6.0-rc3 Released Tue Mar 31 17:42:39 CEST 2020 ================================================================================ Upgrade urgency CRITICAL: A connection management bug introduced with the SSL implementation can crash Redis easily. Dear users, this is a list of the major changes in this release, please check the list of commits for detail: * Fix crash due to refactoring for SSL, for the connection code. * Precise timeouts for blocking commands. Now the timeouts have HZ resolution regardless of the number of connected clinets. New timeouts are stored in a radix tree and sorted by expire time. * Fix rare crash when resizing the event loop because of CONFIG maxclients. * Fix systemd readiness after successful partial resync. * Redis-cli ask password mode to be prompted at startup (for additional safety). * Keyspace notifications added to MIGRATE / RESTORE. * Threaded I/O bugs fixed. * Implement new ACL style AUTH in Sentinel. * Make 'requirepass' more backward compatible with Redis <= 5. * ACL: Handle default user as disabled if it's off regardless of "nopass". * Fix a potential inconsistency when upgrading an instance in Redis Cluster and restarting it. The instance will act as a replica but will actually be set as a master immediately. However the choice of what to do with already expired keys, on loading, was made from the POV of replicas. * Abort transactions after -READONLY error. * Many different fixes to module APIs. * BITFIELD_RO added to call the command on read only replicas. * PSYNC2: meaningful offset implementation. Allow the disconnected master that is still sending PINGs to replicas, to be able to successfully PSYNC incrementally to new slaves, discarding the last part of the replication backlog consisting only of PINGs. * Fix pipelined MULTI/EXEC during Lua scripts are in BUSY state. * Re-fix propagation API in modules, broken again after other changes. antirez in commit ef1b1f01: cast raxSize() to avoid warning with format spec. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 9f347fab: Minor changes to #7037. 2 files changed, 14 insertions(+), 5 deletions(-) Guy Benoish in commit a509400d: Modules: Test MULTI/EXEC replication of RM_Replicate 6 files changed, 49 insertions(+), 9 deletions(-) Guy Benoish in commit 805c8c94: RENAME can unblock XREADGROUP 3 files changed, 25 insertions(+), 1 deletion(-) antirez in commit 97b80b57: Fix the propagate Tcl test after module changes. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 4f6b6b80: Modify the propagate unit test to show more cases. 1 file changed, 30 insertions(+), 2 deletions(-) antirez in commit 616b1cb7: Fix module commands propagation double MULTI bug. 4 files changed, 25 insertions(+), 8 deletions(-) antirez in commit 08fdef4b: Fix RM_Call() stale comment due to cut&paste. 1 file changed, 1 insertion(+), 3 deletions(-) OMG-By in commit 26b79ca1: fix: dict.c->dictResize()->minimal type 1 file changed, 1 insertion(+), 1 deletion(-) zhaozhao.zz in commit fa418637: PSYNC2: reset backlog_idx and master_repl_offset correctly 1 file changed, 10 insertions(+), 5 deletions(-) antirez in commit bbbc80ac: Precise timeouts: reference client pointer directly. 1 file changed, 13 insertions(+), 16 deletions(-) antirez in commit c3b268a0: timeout.c created: move client timeouts code there. 5 files changed, 198 insertions(+), 167 deletions(-) Oran Agra in commit 0f7dfc37: AOFRW on an empty stream created with MKSTREAM loads badkly 2 files changed, 15 insertions(+), 1 deletion(-) antirez in commit 67643ead: Precise timeouts: cleaup the table on unblock. 3 files changed, 21 insertions(+), 2 deletions(-) antirez in commit ad94066e: Precise timeouts: fix comments after functional change. 2 files changed, 6 insertions(+), 6 deletions(-) antirez in commit a443ec2e: Precise timeouts: use only radix tree for timeouts. 3 files changed, 15 insertions(+), 38 deletions(-) antirez in commit 6862fd70: Precise timeouts: fast exit for clientsHandleShortTimeout(). 1 file changed, 1 insertion(+) antirez in commit 30f1df8c: Precise timeouts: fix bugs in initial implementation. 2 files changed, 5 insertions(+), 1 deletion(-) antirez in commit 7add0f24: Precise timeouts: working initial implementation. 3 files changed, 110 insertions(+), 28 deletions(-) antirez in commit 9d6d1779: Precise timeouts: refactor unblocking on timeout. 2 files changed, 33 insertions(+), 13 deletions(-) antirez in commit 316a8f15: PSYNC2: fix backlog_idx when adjusting for meaningful offset 1 file changed, 3 insertions(+) 伯成 in commit 11db53f8: Boost up performance for redis PUB-SUB patterns matching 3 files changed, 43 insertions(+), 11 deletions(-) antirez in commit e257f121: PSYNC2: meaningful offset test. 2 files changed, 62 insertions(+) antirez in commit 5f72f696: PSYNC2: meaningful offset implemented. 3 files changed, 40 insertions(+), 1 deletion(-) antirez in commit 8caa2714: Explain why we allow transactions in -BUSY state. 1 file changed, 9 insertions(+), 2 deletions(-) Oran Agra in commit e43cd831: MULTI/EXEC during LUA script timeout are messed up 2 files changed, 73 insertions(+) antirez in commit 34b89832: Improve comments of replicationCacheMasterUsingMyself(). 1 file changed, 6 insertions(+), 1 deletion(-) antirez in commit 70a98a43: Fix BITFIELD_RO test. 2 files changed, 5 insertions(+), 5 deletions(-) antirez in commit 8783304a: Abort transactions after -READONLY error. Fix #7014. 1 file changed, 1 insertion(+) antirez in commit ec9cf002: Minor changes to BITFIELD_RO PR #6951. 1 file changed, 9 insertions(+), 6 deletions(-) bodong.ybd in commit b3e4abf0: Added BITFIELD_RO variants for read-only operations. 4 files changed, 54 insertions(+), 1 deletion(-) antirez in commit 50f8f950: Modules: updated function doc after #7003. 1 file changed, 6 insertions(+), 1 deletion(-) Guy Benoish in commit f2f3dc5e: Allow RM_GetContextFlags to work with ctx==NULL 1 file changed, 16 insertions(+), 14 deletions(-) hwware in commit eb808879: fix potentical memory leak in redis-cli 1 file changed, 2 insertions(+) Yossi Gottlieb in commit cdcab0e8: Fix crashes related to failed/rejected accepts. 1 file changed, 6 insertions(+), 5 deletions(-) Yossi Gottlieb in commit 50dcd9f9: Cluster: fix misleading accept errors. 1 file changed, 4 insertions(+), 3 deletions(-) Yossi Gottlieb in commit 87dbd8f5: Conns: Fix connClose() / connAccept() behavior. 3 files changed, 48 insertions(+), 32 deletions(-) hwware in commit 81e8686c: remove redundant Semicolon 1 file changed, 1 insertion(+), 1 deletion(-) hwware in commit c7524a7e: clean CLIENT_TRACKING_CACHING flag when disabled caching 1 file changed, 1 insertion(+), 1 deletion(-) hwware in commit 2dd1ca6a: add missing commands in cluster help 1 file changed, 2 insertions(+), 1 deletion(-) artix in commit 95324b81: Support Redis Cluster Proxy PROXY INFO command 1 file changed, 5 insertions(+), 1 deletion(-) 박승현 in commit 04c53fa1: Update redis.conf 1 file changed, 1 insertion(+), 1 deletion(-) WuYunlong in commit 0578157d: Fix master replica inconsistency for upgrading scenario. 3 files changed, 9 insertions(+), 2 deletions(-) WuYunlong in commit 299f1d02: Add 14-consistency-check.tcl to prove there is a data consistency issue. 1 file changed, 87 insertions(+) antirez in commit 61b98f32: Regression test for #7011. 1 file changed, 7 insertions(+) antirez in commit 34ea2f4e: ACL: default user off should not allow automatic authentication. 2 files changed, 3 insertions(+), 2 deletions(-) antirez in commit cbbf9b39: Sentinel: document auth-user directive. 1 file changed, 12 insertions(+) antirez in commit 9c2e42dd: ACL: Make Redis 6 more backward compatible with requirepass. 4 files changed, 17 insertions(+), 15 deletions(-) antirez in commit d387f67d: Sentinel: implement auth-user directive for ACLs. 1 file changed, 38 insertions(+), 7 deletions(-) zhaozhao.zz in commit 7c078416: Threaded IO: bugfix client kill may crash redis 1 file changed, 11 insertions(+), 5 deletions(-) zhaozhao.zz in commit 9cc7038e: Threaded IO: handle pending reads clients ASAP after event loop 1 file changed, 3 insertions(+), 1 deletion(-) antirez in commit da8c7c49: Example sentinel conf: document requirepass. 1 file changed, 8 insertions(+) antirez in commit bdb338cf: Aesthetic changes in PR #6989. 1 file changed, 9 insertions(+), 5 deletions(-) zhaozhao.zz in commit b3e03054: Threaded IO: bugfix #6988 process events while blocked 1 file changed, 5 insertions(+) antirez in commit e628f944: Restore newline at the end of redis-cli.c 1 file changed, 2 insertions(+), 1 deletion(-) chendianqiang in commit 5d4c4df3: use correct list for moduleUnregisterUsedAPI 1 file changed, 1 insertion(+), 1 deletion(-) guodongxiaren in commit da14982d: string literal should be const char* 1 file changed, 1 insertion(+), 1 deletion(-) Itamar Haber in commit dc8885a1: Adds keyspace notifications to migrate and restore 1 file changed, 3 insertions(+), 1 deletion(-) bodong.ybd in commit bfb18e55: Remove duplicate obj files in Makefile 1 file changed, 2 insertions(+), 2 deletions(-) bodong.ybd in commit 76d57161: Fix bug of tcl test using external server 2 files changed, 8 insertions(+), 2 deletions(-) fengpf in commit 0e5820d8: fix comments in latency.c 2 files changed, 2 insertions(+), 1 deletion(-) antirez in commit 916dd79f: Update linenoise. 1 file changed, 2 insertions(+), 1 deletion(-) lifubang in commit c0c67c9b: add askpass mode 1 file changed, 19 insertions(+), 1 deletion(-) lifubang in commit e1c29434: update linenoise to https://github.com/antirez/linenoise/tree/fc9667a81d43911a6690fb1e68c16e6e3bb8df05 4 files changed, 59 insertions(+), 4 deletions(-) Jamie Scott in commit e5a063bc: Remove default guidance in Redis.conf 1 file changed, 1 insertion(+), 2 deletions(-) Jamie Scott in commit d28cbaf7: Update Redis.conf to improve TLS usability 1 file changed, 2 insertions(+), 1 deletion(-) Johannes Truschnigg in commit 23d5e8b8: Signal systemd readiness atfer Partial Resync 1 file changed, 4 insertions(+) Oran Agra in commit 61738154: fix for flaky psync2 test 1 file changed, 21 insertions(+) antirez in commit 70e0e499: ae.c: fix crash when resizing the event loop. 1 file changed, 6 insertions(+), 2 deletions(-) antirez in commit b3e4aa67: Fix release notes spelling mistake. 1 file changed, 1 insertion(+), 1 deletion(-) ================================================================================ Redis 6.0 RC2 Released Thu Mar 05 15:40:53 CET 2020 ================================================================================ Upgrade urgency MODERATE: Normal bugfixing release of a non-GA branch. Hi Redis users, Redis 6 is approaching and will be released 30th of April. New release candidates will be released at the end of March, then another one mid April, to finally reach the GA at the end of April. Redis 6 RC2 brings many fixes and new things, especially in the area of client side caching. This is the list of big changes in this release. As usually you can find the full list of commits at the end: New features and improvements: * ACL LOG: log denied commands, keys accesses and authentications. * Client side caching redesigned. Now we use keys not caching slots. * Client side caching: Broadcasting mode implemented. * Client side caching: OPTIN/OPTOUT modes implemented. * Remove RDB files used for replication in persistence-less instances (option). Fixes (only selected ones, see commits for all the fixes): * Different fixes to streams in edge cases. * Fix duplicated CLIENT SETNAME reply because of RESP3 changes. * Fix crash due to new active expire division by zero. * Avoid sentinel changes promoted_slave to be its own replica. * Fix bug on KEYS command where pattern starts with * followed by \x00. * Threaded I/O: now the main thread is used as well to do I/O. * Many fixes to modules APIs, and more to come in the next RCs. * ld2string should fail if string contains \0 in the middle. * Make the Redis test more reliable. * Fix SPOP returning nil (see #4709). WARNING: API change. qetu3790 in commit 4af0d7fd: Fix not used constant in lru_test_mode. 1 file changed, 1 insertion(+), 1 deletion(-) hwware in commit 6ef01878: add missing file marco 1 file changed, 5 insertions(+) ShooterIT in commit fe81d5c8: Avoid compiler warnings 1 file changed, 1 insertion(+) antirez in commit c2f01d7f: RDB deletion: document it in example redis.conf. 1 file changed, 13 insertions(+) antirez in commit 127e09bc: Make sync RDB deletion configurable. Default to no. 3 files changed, 22 insertions(+), 4 deletions(-) antirez in commit a20303c6: Check that the file exists in removeRDBUsedToSyncReplicas(). 1 file changed, 8 insertions(+), 4 deletions(-) antirez in commit 7a23b945: Log RDB deletion in persistence-less instances. 1 file changed, 15 insertions(+), 2 deletions(-) antirez in commit baaf869f: Introduce bg_unlink(). 1 file changed, 31 insertions(+), 3 deletions(-) antirez in commit be4bc1a5: Remove RDB files used for replication in persistence-less instances. 3 files changed, 56 insertions(+), 1 deletion(-) antirez in commit 07dc1b42: Use a smaller getkeys global buffer. 1 file changed, 1 insertion(+), 1 deletion(-) Oran Agra in commit 10e71b3d: Optimize temporary memory allocations for getKeysFromCommand mechanism 1 file changed, 31 insertions(+), 10 deletions(-) antirez in commit edc0ed14: Modules: reformat RM_Scan() top comment a bit. 1 file changed, 21 insertions(+), 12 deletions(-) antirez in commit c5319612: Modules: more details in RM_Scan API top comment. 1 file changed, 22 insertions(+), 6 deletions(-) Oran Agra in commit fff6b26a: RM_Scan disable dict rehashing 2 files changed, 21 insertions(+), 6 deletions(-) Guy Benoish in commit 65048460: Add RM_CreateStringFromDouble 2 files changed, 14 insertions(+) Oran Agra in commit 3144a278: add no_auth to COMMAND INFO 1 file changed, 1 insertion(+) Oran Agra in commit afe0b16c: module api docs for aux_save and aux_load 2 files changed, 7 insertions(+), 1 deletion(-) Guy Benoish in commit df152b0c: streamReplyWithRangeFromConsumerPEL: Redundant streamDecodeID 1 file changed, 1 insertion(+), 3 deletions(-) antirez in commit e3c1f439: Show Redis version when not understanding a config directive. 1 file changed, 2 insertions(+), 1 deletion(-) antirez in commit 141c0679: Changelog: explain Redis 6 SPOP change. 1 file changed, 4 insertions(+), 1 deletion(-) bodong.ybd in commit fe902461: Fix spop return nil #4709 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 9d4219eb: Fix SDS misuse in enumConfigSet(). Related to #6778. 1 file changed, 3 insertions(+), 3 deletions(-) antirez in commit 84243064: Remove useless comment from enumConfigSet(). 1 file changed, 1 deletion(-) Ponnuvel Palaniyappan in commit dafb94db: Fix a potential overflow with strncpy 1 file changed, 5 insertions(+), 5 deletions(-) antirez in commit ea697b63: Improve aeDeleteEventLoop() top comment grammar. 1 file changed, 2 insertions(+), 1 deletion(-) wangyuan21 in commit dd479880: free time event when delete eventloop 1 file changed, 7 insertions(+) srzhao in commit ecf3b2ef: fix impl of aof-child whitelist SIGUSR1 feature. 1 file changed, 5 insertions(+), 4 deletions(-) meir@redislabs.com in commit 2966132c: Changed log level for module fork api from 'notice' to 'verbos'. 1 file changed, 2 insertions(+), 2 deletions(-) hwware in commit 7277e5d8: format fix 1 file changed, 1 insertion(+), 1 deletion(-) hwware in commit 1bb5ee9c: fix potentical memory leaks 1 file changed, 4 insertions(+), 1 deletion(-) Hengjian Tang in commit 97329733: modify the read buf size according to the write buf size PROTO_IOBUF_LEN defined before 1 file changed, 1 insertion(+), 1 deletion(-) Ariel in commit 15ea1324: fix ThreadSafeContext lock/unlock function names 1 file changed, 2 insertions(+), 2 deletions(-) Guy Benoish in commit 4d12c37c: XREADGROUP should propagate XCALIM/SETID in MULTI/EXEC 1 file changed, 2 insertions(+), 2 deletions(-) Oran Agra in commit 12626ce9: fix race in module api test for fork 2 files changed, 2 insertions(+), 3 deletions(-) Guy Benoish in commit 2ecab0b6: Modules: Do not auto-unblock clients if not blocked on keys 1 file changed, 22 insertions(+), 7 deletions(-) Oran Agra in commit 635321d4: fix github actions failing latency test for active defrag - part 2 2 files changed, 5 insertions(+), 4 deletions(-) Oran Agra in commit 0b988fa9: fix github actions failing latency test for active defrag 2 files changed, 14 insertions(+), 13 deletions(-) Oran Agra in commit 60096bc1: Fix latency sensitivity of new defrag test 1 file changed, 32 insertions(+), 8 deletions(-) antirez in commit b4395426: Tracking: optin/out implemented. 3 files changed, 82 insertions(+), 16 deletions(-) antirez in commit ef3551d1: Test engine: experimental change to avoid busy port problems. 1 file changed, 84 insertions(+), 49 deletions(-) antirez in commit 72c05351: Test engine: detect timeout when checking for Redis startup. 1 file changed, 11 insertions(+), 1 deletion(-) antirez in commit 294c9af4: Test engine: better tracking of what workers are doing. 2 files changed, 12 insertions(+), 4 deletions(-) hwware in commit ba027079: add missing subcommand description for debug oom 1 file changed, 1 insertion(+) Guy Benoish in commit 5d0890c0: Fix memory leak in test_ld_conv 1 file changed, 4 insertions(+) Madelyn Olson in commit d1f22eac: Give an error message if you specify redirect twice 1 file changed, 7 insertions(+) Madelyn Olson in commit 762fbcb6: Minor CSC fixes and fixed documentation 2 files changed, 16 insertions(+), 17 deletions(-) Oran Agra in commit 349aa245: Defrag big lists in portions to avoid latency and freeze 4 files changed, 350 insertions(+), 34 deletions(-) Guy Benoish in commit b4ddc7b7: XGROUP DESTROY should unblock XREADGROUP with -NOGROUP 2 files changed, 11 insertions(+) hayashier in commit 73806f74: fix typo from fss to rss 1 file changed, 2 insertions(+), 2 deletions(-) antirez in commit b6129f86: Test is more complex now, increase default timeout. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit f15fb727: Tracking: fix max-keys configuration directive. 2 files changed, 2 insertions(+), 2 deletions(-) Itamar Haber in commit e374573f: Fixes segfault on calling trackingGetTotalKeys 1 file changed, 1 insertion(+) antirez in commit 73d47d57: Signal key as modified when expired on-access. 1 file changed, 4 insertions(+), 2 deletions(-) antirez in commit b7cb28d5: Tracking: first set of tests for the feature. 1 file changed, 66 insertions(+) antirez in commit 1db72571: Tracking: fix operators precedence error in bcast check. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit fe96e29d: Tracking: fix behavior when switchinig from normal to BCAST. 1 file changed, 11 insertions(+), 1 deletion(-) antirez in commit f21be1ec: Tracking: fix sending messages bug + tracking off bug. 2 files changed, 28 insertions(+), 20 deletions(-) antirez in commit 6fb1aa23: Tracking: BCAST: basic feature now works. 3 files changed, 55 insertions(+), 40 deletions(-) antirez in commit d4fe79a1: Tracking: BCAST: broadcasting of keys in prefixes implemented. 2 files changed, 94 insertions(+), 9 deletions(-) antirez in commit abb81c63: Tracking: BCAST: registration in the prefix table. 3 files changed, 67 insertions(+), 20 deletions(-) antirez in commit 77da9608: Tracking: BCAST: parsing of the options + skeleton. 4 files changed, 73 insertions(+), 19 deletions(-) antirez in commit 3e8c69a9: Tracking: always reply with an array of keys. 2 files changed, 10 insertions(+), 3 deletions(-) antirez in commit a788c373: Tracking: minor change of names and new INFO field. 4 files changed, 11 insertions(+), 4 deletions(-) antirez in commit df838927: Rax.c: populate data field after random walk. 1 file changed, 1 insertion(+) antirez in commit 0517da36: Tracking: rename INFO field with total items. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 3c16d6b3: Tracking: first conversion from hashing to key names. 3 files changed, 84 insertions(+), 114 deletions(-) Oran Agra in commit 3b4f1477: add no-slowlog option to RM_CreateCommand 1 file changed, 3 insertions(+) Khem Raj in commit 5e762d84: Mark extern definition of SDS_NOINIT in sds.h 1 file changed, 1 insertion(+), 1 deletion(-) lifubang in commit 54f5499a: correct help info for --user and --pass 1 file changed, 2 insertions(+), 2 deletions(-) Seunghoon Woo in commit 0c952b13: [FIX] revisit CVE-2015-8080 vulnerability 1 file changed, 6 insertions(+), 4 deletions(-) Guy Benoish in commit dd34f703: Diskless-load emptyDb-related fixes 3 files changed, 44 insertions(+), 28 deletions(-) lifubang in commit 5e042dbc: fix ssl flag check for redis-cli 1 file changed, 10 insertions(+), 9 deletions(-) Guy Benoish in commit dcbe8bfa: Exclude "keymiss" notification from NOTIFY_ALL 5 files changed, 12 insertions(+), 7 deletions(-) Oran Agra in commit 36caf2e4: update RM_SignalModifiedKey doc comment 1 file changed, 2 insertions(+), 1 deletion(-) Oran Agra in commit 3067352a: Add handling of short read of module id in rdb 1 file changed, 4 insertions(+), 1 deletion(-) Yossi Gottlieb in commit 9baaf858: TLS: Update documentation. 2 files changed, 32 insertions(+), 31 deletions(-) Oran Agra in commit 4440133e: A few non-data commands that should be allowed while loading or stale 1 file changed, 8 insertions(+), 8 deletions(-) Oran Agra in commit c9577941: Memory leak when bind config is provided twice 1 file changed, 4 insertions(+) Oran Agra in commit 1333a46b: fix maxmemory config warning 1 file changed, 3 insertions(+), 2 deletions(-) Oran Agra in commit 8e7282eb: Fix client flags to be int64 in module.c 1 file changed, 3 insertions(+), 3 deletions(-) Oran Agra in commit a678390e: moduleRDBLoadError, add key name, and use panic rather than exit 1 file changed, 5 insertions(+), 4 deletions(-) Oran Agra in commit 919fbf42: reduce repeated calls to use_diskless_load 1 file changed, 3 insertions(+), 4 deletions(-) Oran Agra in commit 22e45d46: freeClientAsync don't lock mutex if there's just one thread 1 file changed, 6 insertions(+), 1 deletion(-) Oran Agra in commit ba289244: move restartAOFAfterSYNC from replicaofCommand to replicationUnsetMaster 1 file changed, 4 insertions(+), 3 deletions(-) Oran Agra in commit f42ce57d: stopAppendOnly resets aof_rewrite_scheduled 1 file changed, 1 insertion(+) Oran Agra in commit df096bc9: add SAVE subcommand to ACL HELP and top comment 1 file changed, 2 insertions(+) Oran Agra in commit a55e5847: DEBUG HELP - add PROTOCOL 1 file changed, 3 insertions(+), 2 deletions(-) Guy Benoish in commit 5a6cfbf4: Some refactroing using getClientType instead of CLIENT_SLAVE 2 files changed, 18 insertions(+), 26 deletions(-) Guy Benoish in commit fae306b3: Fix small bugs related to replica and monitor ambiguity 2 files changed, 8 insertions(+), 6 deletions(-) Yossi Gottlieb in commit 73630966: TLS: Some redis.conf clarifications. 1 file changed, 10 insertions(+), 11 deletions(-) Oran Agra in commit 488e1947: config.c verbose error replies for CONFIG SET, like config file parsing 1 file changed, 31 insertions(+), 97 deletions(-) Oran Agra in commit c82ccf06: memoryGetKeys helper function so that ACL can limit access to keys for MEMORY command 3 files changed, 18 insertions(+), 1 deletion(-) antirez in commit 51c1a9f8: ACL LOG: make max log entries configurable. 4 files changed, 19 insertions(+) antirez in commit ea1e1b12: ACL LOG: test for AUTH reason. 1 file changed, 9 insertions(+) antirez in commit 7379c78a: ACL LOG: log failed auth attempts. 5 files changed, 34 insertions(+), 12 deletions(-) antirez in commit 9f6e84f6: ACL LOG: implement a few basic tests. 1 file changed, 87 insertions(+) antirez in commit 82790e51: ACL LOG: also log ACL errors in the scripting/MULTI ctx. 2 files changed, 6 insertions(+), 2 deletions(-) antirez in commit 943008eb: ACL LOG: implement LOG RESET. 1 file changed, 6 insertions(+), 2 deletions(-) antirez in commit e271a611: ACL LOG: group similar entries in a given time delta. 1 file changed, 58 insertions(+), 3 deletions(-) antirez in commit f1974d5d: ACL LOG: actually emit entries. 3 files changed, 34 insertions(+), 5 deletions(-) antirez in commit d9b153c9: ACL LOG: implement ACL LOG subcommadn skeleton. 1 file changed, 37 insertions(+) antirez in commit 577fc438: ACL LOG: data structures and initial functions. 5 files changed, 54 insertions(+), 5 deletions(-) Leo Murillo in commit f7a94526: Set ZSKIPLIST_MAXLEVEL to optimal value given 2^64 elements and p=0.25 1 file changed, 1 insertion(+), 1 deletion(-) WuYunlong in commit eecfa979: Fix lua related memory leak. 1 file changed, 1 insertion(+) WuYunlong in commit d2509811: Add tcl regression test in scripting.tcl to reproduce memory leak. 1 file changed, 5 insertions(+) Yossi Gottlieb in commit 29d4a150: TLS: Fix missing initialization in redis-cli. 1 file changed, 9 insertions(+) Oran Agra in commit ec0c61da: fix uninitialized info_cb var in module.c 1 file changed, 1 insertion(+) Guy Benoish in commit 6fe55c2f: ld2string should fail if string contains \0 in the middle 5 files changed, 20 insertions(+), 11 deletions(-) antirez in commit bbce3ba9: Add more info in the unblockClientFromModule() function. 1 file changed, 7 insertions(+), 1 deletion(-) Guy Benoish in commit 40295fb3: Modules: Fix blocked-client-related memory leak 3 files changed, 51 insertions(+), 6 deletions(-) antirez in commit 8e9d19bc: Change error message for #6775. 1 file changed, 2 insertions(+), 2 deletions(-) Vasyl Melnychuk in commit ba146d4c: Make error when submitting command in incorrect context more explicit 1 file changed, 4 insertions(+), 1 deletion(-) antirez in commit 721a39dd: Document I/O threads in redis.conf. 1 file changed, 46 insertions(+) antirez in commit 5be3a15a: Setting N I/O threads should mean N-1 additional + 1 main thread. 1 file changed, 25 insertions(+), 22 deletions(-) antirez in commit cbabf779: Simplify #6379 changes. 2 files changed, 4 insertions(+), 9 deletions(-) WuYunlong in commit 658749cc: Free allocated sds in pfdebugCommand() to avoid memory leak. 1 file changed, 1 insertion(+) WuYunlong in commit 47988c96: Fix potential memory leak of clusterLoadConfig(). 1 file changed, 20 insertions(+), 5 deletions(-) WuYunlong in commit cc90f79b: Fix potential memory leak of rioWriteBulkStreamID(). 1 file changed, 4 insertions(+), 1 deletion(-) antirez in commit ecd17e81: Jump to right label on AOF parsing error. 1 file changed, 6 insertions(+), 4 deletions(-) antirez in commit 1927932b: Port PR #6110 to new connection object code. 1 file changed, 2 insertions(+), 2 deletions(-) antirez in commit f2df5773: A few comments about main thread serving I/O as well. 1 file changed, 7 insertions(+), 1 deletion(-) zhaozhao.zz in commit b3ff8a4b: Threaded IO: use main thread to handle read work 1 file changed, 8 insertions(+), 1 deletion(-) zhaozhao.zz in commit b1f2c510: Threaded IO: use main thread to handle write work 1 file changed, 10 insertions(+), 2 deletions(-) ShooterIT in commit 7bbafc56: Rename rdb asynchronously 1 file changed, 7 insertions(+) Leo Murillo in commit c7f75266: Fix bug on KEYS command where pattern starts with * followed by \x00 (null char). 1 file changed, 1 insertion(+), 1 deletion(-) Jamie Scott in commit ed7ea13a: Update to directive in redis.conf (missing s) 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 3be77623: Free fakeclient argv on AOF error. 1 file changed, 11 insertions(+), 3 deletions(-) antirez in commit 15f6b748: Git ignore: ignore more files. 1 file changed, 2 insertions(+) Guy Benoish in commit 1b5bf40c: Blocking XREAD[GROUP] should always reply with valid data (or timeout) 3 files changed, 44 insertions(+), 10 deletions(-) John Sully in commit 954c20ed: Add support for incremental build with header files 2 files changed, 6 insertions(+), 1 deletion(-) WuYunlong in commit 11c3afd7: Fix petential cluster link error. 1 file changed, 4 insertions(+) Yossi Gottlieb in commit b752e83d: Add REDISMODULE_CTX_FLAGS_MULTI_DIRTY. 2 files changed, 8 insertions(+) hwware in commit e16eb874: typo fix in acl.c 1 file changed, 2 insertions(+), 2 deletions(-) Itamar Haber in commit 35ea9d23: Adjusts 'io_threads_num' max to 128 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 38729126: XCLAIM: Create the consumer only on successful claims. 1 file changed, 4 insertions(+), 2 deletions(-) yz1509 in commit b9a15303: avoid sentinel changes promoted_slave to be its own replica. 1 file changed, 1 insertion(+), 1 deletion(-) antirez in commit 5e7e5e6b: Fix active expire division by zero. 1 file changed, 7 insertions(+), 4 deletions(-) antirez in commit e61dde88: Fix duplicated CLIENT SETNAME reply. 1 file changed, 1 deletion(-) Guy Benoish in commit cddf1da2: Stream: Handle streamID-related edge cases 4 files changed, 54 insertions(+), 4 deletions(-) Oran Agra in commit 52ea44e5: config.c adjust config limits and mutable 2 files changed, 7 insertions(+), 7 deletions(-) antirez in commit 0f28ea16: Inline protocol: handle empty strings well. 1 file changed, 2 insertions(+), 6 deletions(-) antirez in commit 00e5fefe: Fix ip and missing mode in RM_GetClusterNodeInfo(). 1 file changed, 5 insertions(+), 2 deletions(-) ================================================================================ Redis 6.0 RC1 Released Thu Dec 19 09:58:24 CEST 2019 ================================================================================ Upgrade urgency LOW: This is the first RC of Redis 6. Introduction to the Redis 6 release =================================== Redis 6 improves Redis in a number of key areas and is one of the largest Redis releases in the history of the project, so here we'll list only the biggest features in this release: * The modules system now has a number of new APIs that allow module authors to make things otherwise not possible in the past. It is possible to store arbitrary module private data in RDB files, to hook on different server events, capture and rewrite commands executions, block clients on keys, and so forth. * The Redis active expire cycle was rewritten for much faster eviction of keys that are already expired. Now the effort is tunable. * Redis now supports SSL on all channels. * ACL support, you can define users that can run only certain commands and/or can only access only certain keys patterns. * Redis now supports a new protocol called RESP3, which returns more semantical replies: new clients using this protocol can understand just from the reply what type to return to the calling program. * There is server-side support for client-side caching of key values. This feature is still experimental and will get more changes during the next release candidates, but you can already test it and read about it here: https://redis.io/topics/client-side-caching * Redis can now optionally use threads to handle I/O, allowing to serve 2 times as much operations per second in a single instance when pipelining cannot be used. * Diskless replication is now supported even on replicas: a replica is now able, under certain conditions the user can configure, to load the RDB in the first synchronization directly from the socket to the memory. * Redis-benchmark now supports a Redis Cluster mode. * SRANDMEMBER and similar commands have a better distribution. * Redis-cli improvements. * Systemd support rewritten. * A Redis Cluster proxy was released here: https://github.com/artix75/redis-cluster-proxy * A Disque module for Redis was released here: https://github.com/antirez/disque-module Thanks to all the users and developers who made this release possible. We'll follow up with more RC releases, until the code looks production ready and we don't get reports of serious issues for a while. A special thank you for the amount of work put into this release (in decreasing number of commits, only listing contributors with more than a single commit) by: 685 antirez 81 zhaozhao.zz 76 Oran Agra 51 artix 28 Madelyn Olson 27 Yossi Gottlieb 15 David Carlier 14 Guy Benoish 14 Guy Korland 13 Itamar Haber 9 Angus Pearson 8 WuYunlong 8 yongman 7 vattezhang 7 Chris Lamb 5 Dvir Volk 5 meir@redislabs.com 5 chendianqiang 5 John Sully 4 dejun.xdj 4 Daniel Dai 4 Johannes Truschnigg 4 swilly22 3 Bruce Merry 3 filipecosta90 3 youjiali1995 2 James Rouzier 2 Andrey Bugaevskiy 2 Brad Solomon 2 Hamid Alaei 2 Michael Chaten 2 Steve Webster 2 Wander Hillen 2 Weiliang Li 2 Yuan Zhou 2 charsyam 2 hujie 2 jem 2 shenlongxing 2 valentino 2 zhudacai 00228490 2 喜欢兰花山丘 Migrating from 5.0 to 6.0 ========================= Redis 6.0 is mostly a strict superset of 5.0, you should not have any problem upgrading your application from 5.0 to 6.0. However this is a list of small non-backward compatible changes introduced in the 6.0 release: * The SPOP command no longer returns null when the set key does not exist. Now it returns the empty set as it should and as happens when it is called with a 0 argument. This is technically a fix, however it changes the old behavior. -------------------------------------------------------------------------------- Credits: For each release, a list of changes with the relative author is provided. Where not specified the implementation and design is done by Salvatore Sanfilippo. Thanks to Redis Labs for making all this possible. Also many thanks to all the other contributors and the amazing community we have. Commit messages may contain additional credits. Enjoy, Salvatore