From 7b2fd6fcf1cce52a3a3fa582bf0956ae246abd8b Mon Sep 17 00:00:00 2001 From: suxb201 Date: Fri, 22 Nov 2024 10:57:52 +0800 Subject: [PATCH] feat: add RDB_OPCODE_SLOT_INFO support for Redis 7.4 (#881) --- README.md | 2 +- internal/rdb/rdb.go | 11 +++++++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index e360947c..f434835d 100644 --- a/README.md +++ b/README.md @@ -18,7 +18,7 @@ RedisShake is a powerful tool for Redis data transformation and migration, offer 1. **Zero Downtime Migration**: Enables seamless data migration without data loss or service interruption, ensuring continuous operation during the transfer process. -2. **Redis Compatibility**: Supports Redis 2.8 to 7.2, across standalone, master-slave, sentinel, and cluster deployments. +2. **Redis Compatibility**: Supports Redis 2.8 to 7.4, across standalone, master-slave, sentinel, and cluster deployments. 3. **Cloud Service Integration**: Seamlessly works with Redis-like databases from major cloud providers: - Alibaba Cloud: [ApsaraDB for Redis](https://www.alibabacloud.com/product/apsaradb-for-redis), [Tair](https://www.alibabacloud.com/product/tair) diff --git a/internal/rdb/rdb.go b/internal/rdb/rdb.go index 70119150..28412368 100644 --- a/internal/rdb/rdb.go +++ b/internal/rdb/rdb.go @@ -18,8 +18,9 @@ import ( ) const ( - kFlagFunction2 = 245 // function library data - kFlagFunction = 246 // old function library data for 7.0 rc1 and rc2 + kFlagSlotInfo = 244 // (Redis 7.4) RDB_OPCODE_SLOT_INFO: slot info + kFlagFunction2 = 245 // RDB_OPCODE_FUNCTION2: function library data + kFlagFunction = 246 // RDB_OPCODE_FUNCTION_PRE_GA: old function library data for 7.0 rc1 and rc2 kFlagModuleAux = 247 // RDB_OPCODE_MODULE_AUX: Module auxiliary data. kFlagIdle = 248 // RDB_OPCODE_IDLE: LRU idle time. kFlagFreq = 249 // RDB_OPCODE_FREQ: LFU frequency. @@ -124,6 +125,12 @@ func (ld *Loader) parseRDBEntry(ctx context.Context, rd *bufio.Reader) { typeByte := structure.ReadByte(rd) log.Debugf("RDB type byte is: [%d]", typeByte) switch typeByte { + case kFlagSlotInfo: + _ = structure.ReadLength(rd) // slot_id + _ = structure.ReadLength(rd) // slot_size + _ = structure.ReadLength(rd) // expires_slot_size + case kFlagFunction, kFlagFunction2: + log.Panicf("function library data not supported, need PR to support") case kFlagModuleAux: moduleId := structure.ReadLength(rd) // module id moduleName := types.ModuleTypeNameByID(moduleId)