9.0.4
Upgrade urgency SECURITY: This release includes security fixes we recommend you apply as soon as possible.
- (CVE-2026-23479) Use-After-Free in unblock client flow
- (CVE-2026-25243) Invalid Memory Access in RESTORE command
- (CVE-2026-23631) Use-after-free when full sync occurs during a yielding Lua/function execution
8.1.7
Upgrade urgency SECURITY: This release includes security fixes we recommend you apply as soon as possible.
- (CVE-2026-23479) Use-After-Free in unblock client flow
- (CVE-2026-25243) Invalid Memory Access in RESTORE command
- (CVE-2026-23631) Use-after-free when full sync occurs during a yielding Lua/function execution
7.2.13
Upgrade urgency SECURITY: This release includes security fixes we recommend you apply as soon as possible.
- (CVE-2026-23479) Use-After-Free in unblock client flow
- (CVE-2026-25243) Invalid Memory Access in RESTORE command
- (CVE-2026-23631) Use-after-free when full sync occurs during a yielding Lua/function execution
8.0.8
Upgrade urgency SECURITY: This release includes security fixes we recommend you apply as soon as possible.
- (CVE-2026-23479) Use-After-Free in unblock client flow
- (CVE-2026-25243) Invalid Memory Access in RESTORE command
- (CVE-2026-23631) Use-after-free when full sync occurs during a yielding Lua/function execution
9.1.0-rc2
Upgrade urgency LOW: This is the second release candidate of Valkey 9.1.0.
- Revert strict TLS certificate validation at config load as it is a breaking change, deferred to next major version (#3572)
- Do the failover immediately if the replica is the best ranked replica by @enjoy-binbin (#2227)
- Add
cluster-config-save-behavioroption to control nodes.conf save behavior by @enjoy-binbin (#3372) - Lua scripting engine is now statically linked by default instead of dynamically linked by @eifrah-aws (#3392)
- Module command result callback addition by @martinrvisser (#2936)
- Redesign IO threading communication model with lock-free queues (8-17% throughput gain) by @akashkgit (#3324)
- Increase embedded string threshold from 64 to 128 bytes (30% GET throughput gain) by @Nikhil-Manglore (#3397)
- ARM NEON SIMD optimization for pvFind() in vset.c (2-3x speedup) by @ahmadbelb (#3033)
- Optimize WATCH duplicate key check from O(N) to O(1) using per-db hashtable by @enjoy-binbin (#3360)
- Optimize
CLUSTERSCAN MATCHso that it uses a specific slot if given by @nmvk (#3380) - Improve COB memory tracking with copy avoidance by @dvkashapov (#3306)
- Fix
valkey-cli --cluster del-nodefor unreachable nodes by @yang-z-o (#3209) - Enhance cluster stale packet detection to prevent sub-replica and empty primary by @zhijun42 (#2811)
- Big endian bitmap byte order mismatch fix by @nmvk (#3401)
- Fix slot-migration-max-failover-repl-bytes unable to accept -1 by @enjoy-binbin (#3443)
- Fix config rewrite producing negative values for unsigned memory configs by @enjoy-binbin (#3440)
- Fix HPERSIST RESP protocol violation on wrong-type key by @madolson (#3516)
- Fix lua-enable-insecure-api default value cannot be changed to yes by @enjoy-binbin (#3548)
Full Changelog: https://github.com/valkey-io/valkey/compare/9.1.0-rc1...9.1.0-rc2
9.1.0-rc1
Upgrade urgency LOW: This is the first release candidate of Valkey 9.1.0, with new features, performance improvements, and bug fixes.
- Database-level access control by @dvkashapov (#2309)
- Move Lua scripting engine into a Valkey module by @rjd15372 (#2858)
- Support cross node consistency for
SCANcommands through configurable DB hash seed by @sarthakaggarwal97 (#2608) - Support automatic TLS reload by @yang-z-o (#3020)
- Support TLS authentication using SAN URI by @yang-z-o (#3078)
- Prevent invalid TLS certificates from being loaded by @yang-z-o (#2999)
- Failing to save the cluster config file will no longer exit the process by @enjoy-binbin (#1032)
- Makes
CLUSTER KEYSLOTavailable in standalone mode by @stockholmux (#3040) - Update HSETEX so that it always issue keyspace notifications after validation by @ranshid (#3001)
- Adds HGETDEL command by @roshkhatri (#2851)
- Support NX/XX flag in HSETEX command by @hanxizh9910 (#2668)
- New
CLUSTERSCANcommand for cluster-wide key scanning across nodes by @nmvk (#2934) - New
MSETEXcommand to set multiple keys with a shared expiration by @enjoy-binbin (#3121) CLUSTER SHARDS/CLUSTER SLOTSnow include anavailability-zonefield by @bandalgomsu (#3156)
- Optimize zset memory usage by embedding element in skiplist by @chzhoo (#2508)
- Remove internal server object pointer overhead in small strings by @rainsupreme (#2516)
- Optimize skiplist query efficiency by embedding the skiplist header by @chzhoo (#2867)
- Improve performance during rehashing by @chzhoo (#3073)
- Optimize SREM/ZREM/HDEL to pause auto shrink when deleting multiple items by @enjoy-binbin (#3144)
- Abort and swap the tables if ht1 is very full during the hashtable shrink rehashing by @enjoy-binbin (#3175)
- Improve performance of copy avoidance when command reply tracking is disabled by @dvkashapov (#3086)
- Enable hardware clock by default by @dvkashapov (#3103)
- Improve
COMMANDperformance by caching responses by @ebarskiy (#2839) - Add support for asynchronous freeing of keys on writable replicas by @Scut-Corgis (#2849)
- Faster
XRANGE/XREVRANGEvia stream range hot-path optimization by @nesty92 (#3002) - Replicas can reuse the RDB file as AOF preamble after disk-based full sync by @RayaCoo (#1901)
- Add ValkeyModule_ClusterKeySlotC by @bandalgomsu (#2984)
- Add more client info flags to module API by @martinrvisser (#2868)
- Add prefix-aware ACL permission checks and new module API by @eifrah-aws (#2796)
- Support unsigned 64-bit numeric config values in module API by @artikell (#1546)
- Cumulative metrics for active I/O threads usage by @deepakrn (#2463)
- Cumulative metric for active main thread usage by @dvkashapov (#2931)
- Support whole cluster info for INFO command in cluster_info section by @soloestoy, @ranshid (#2876, #2964)
- Add remaining_repl_size field in
CLUSTER GETSLOTMIGRATIONSoutput by @enjoy-binbin (#3135) - Add logging helper function to print node's ip:port when nodename not explicitly set by @zhijun42 (#2777)
- Dual-channel-replication announces itself at replica-announce-ip if configured by @jdheyburn (#2846)
- Show replica dual-channel replication buffer memory in
INFO MEMORYandMEMORY STATSby @enjoy-binbin (#2924) - Add
rdb_transmittedstate to replica state inINFOby @enjoy-binbin (#2833) - New INFO section for scripting engines by @rjd15372 (#2738)
- Adding json support for log-format config by @jbergstroem (#1791)
- Add server side TLS certificate expiry tracking and INFO telemetry by @YiwenZhang12 (#2913)
- Add option to use libbacktrace for backtraces in crash reports by @rainsupreme (#3034)
- Show RPS histogram in valkey-benchmark by @hanxizh9910 (#2471)
- Add --warmup and --duration parameters to valkey-benchmark by @rainsupreme (#2581)
- Lazy loading of RDMA libs in CLI/Benchmark when building as module by @Ada-Church-Closure (#3072)
- Add support for atomic slot migration to valkey-cli by @murphyjacob4 (#2755)
- Replace C++ fast_float dependency with pure C implementation (ffc) by @lemire (#3329)
- Strictly check CRLF when parsing querybuf by @enjoy-binbin (#2872)
- Adam Fowler @adam-fowler
- Aditya Teltia @AdityaTeltia
- Alina Liu @asagege
- Allen Samuels @allenss-amazon
- Alon Arenberg @alon-arenberg
- aradz44 @aradz44
- Arthur Lee @arthurkiller
- bandalgomsu @bandalgomsu
- Baswanth @baswanth09
- Benson-li @li-benson
- Binbin @enjoy-binbin
- Björn Svensson @bjosv
- bpint @bpint
- chzhoo @chzhoo
- cjx-zar @cjx-zar
- Daniil Kashapov @dvkashapov
- Deepak Nandihalli @deepakrn
- Diego Ciciani @diegociciani
- eifrah-aws @eifrah-aws
- Evgeny Barskiy @ebarskiy
- Gabi Ganam @gabiganam
- Gagan H R @gaganhr94
- Hanxi Zhang @hanxizh9910
- Harkrishn Patro @hpatro
- Harry Lin @harrylin98
- hieu2102 @hieu2102
- Jacob Murphy @murphyjacob4
- jiegang0219 @jiegang0219
- Jim Brunner @JimB123
- Johan Bergström @jbergstroem
- John @johnufida
- Joseph Heyburn @jdheyburn
- Katie Holly @Fusl
- Ken @otherscase
- korjeek @korjeek
- Kurt McKee @kurtmckee
- Kyle J. Davis @stockholmux
- Kyle Kim @kyle-yh-kim
- Leon Anavi @leon-anavi
- Madelyn Olson @madolson
- Mangat Singh Toor @immangat
- Marc Jakobi @mrcjkb
- martinrvisser @martinrvisser
- Marvin Rösch @marvinroesch
- Murad Shahmammadli @MuradSh
- NAM UK KIM @namuk2004
- Nikhil Manglore @Nikhil-Manglore
- Ouri Half @ouriamzn
- Patrik Hermansson @phermansson
- Ping Xie @PingXie
- Quanye Yang @Ada-Church-Closure
- Rain Valentine @rainsupreme
- Ran Shidlansik @ranshid
- Ricardo Dias @rjd15372
- Ritoban Dutta @ritoban23
- Roshan Khatri @roshkhatri
- ruihong123 @ruihong123
- Sachin Venkatesha Murthy @sachinvmurthy
- Sarthak Aggarwal @sarthakaggarwal97
- Satheesha CH Gowda @satheesha
- Seungmin Lee @sungming2
- Shinobu Nunotaba @Ada-Church-Closure
- Simon Baatz @gmbnomis
- skyfirelee @artikell
- Sourav Singh Rawat @frostzt
- stydxm @stydxm
- Ted Lyngmo @TedLyngmo
- Tony Wooster @twooster
- uriyage @uriyage
- Vadym Khoptynets @poiuj
- Venkat Pamulapati @ChiliPaneer
- Viktor Söderqvist @zuiderkwast
- Vitah Lin @vitahlin
- Vitali @VitalyAR
- withRiver @withRiver
- wxmzy88 @wxmzy88
- xbasel @xbasel
- Yair Gottdenker @yairgott
- Yana Molodetsky @yanamolo
- Yang Zhao @yang-z-o
- Yiwen Zhang @YiwenZhang12
- yzc-yzc @yzc-yzc
- zhaozhao.zz @soloestoy
- Zhijun Liao @zhijun42
9.0.3
Upgrade urgency SECURITY: This release includes security fixes we recommend you apply as soon as possible.
- (CVE-2025-67733) RESP Protocol Injection via Lua error_reply
- (CVE-2026-21863) Remote DoS with malformed Valkey Cluster bus message
- (CVE-2026-27623) Reset request type after handling empty requests
- Avoids crash during MODULE UNLOAD when ACL rules reference a module command and subcommand (#3160)
- Fix server assert on ACL LOAD when current user loses permission to channels (#3182)
- Fix bug causing no response flush sometimes when IO threads are busy (#3205)
8.1.6
Upgrade urgency SECURITY: This release includes security fixes we recommend you apply as soon as possible.
- (CVE-2026-21863) Remote DoS with malformed Valkey Cluster bus message
- (CVE-2025-67733) RESP Protocol Injection via Lua error_reply
- Restrict ttl from being negative and avoid crash in import-mode (#2944)
- Fix chained replica crash when doing dual channel replication (#2983)
- Fix used_memory_dataset underflow due to miscalculated used_memory_overhead (#3005)
- Fix crashing while MODULE UNLOAD when ACL rules reference a module command or subcommand (#3160)
- Fix server assert on ACL LOAD and resetchannels (#3182)
- Fix bug causing no response flush sometimes when IO threads are busy (#3205)
8.0.7
Upgrade urgency SECURITY: This release includes security fixes we recommend you apply as soon as possible.
- (CVE-2026-21863) Remote DoS with malformed Valkey Cluster bus message
- (CVE-2025-67733) RESP Protocol Injection via Lua error_reply
- Fix ltrim should not call signalModifiedKey when no elements are removed (#2787)
- Fix chained replica crash when doing dual channel replication (#2983)
- Fix used_memory_dataset underflow due to miscalculated used_memory_overhead (#3005)
- Avoids crash during MODULE UNLOAD when ACL rules reference a module command and subcommand (#3160)
- Fix server assert on ACL LOAD and resetchannels (#3182)
- Fix bug causing no response flush sometimes when IO threads are busy (#3205)