问题一:对于写命令,如何进行主备复制和写AOF?
对于写命令,如何进行主备复制和写AOF?
参考回答:
对于写命令,可以使用RedisModule_ReplicateVerbatim或RedisModule_Replicate进行主备复制和写AOF。其中,RedisModule_ReplicateVerbatim会原封不动地复制命令,而RedisModule_Replicate则允许对原命令进行重写。使用RedisModule_Replicate时,产生的AOF前后会被自动加上multi/exec,保证module内产生的命令具有隔离性。如果命令中存在诸如版本号等参数,则必须使用RedisModule_Replicate将版本号重写为绝对版本号,将过期时间重写为绝对过期时间。
关于本问题的更多回答可点击原文查看:
https://developer.aliyun.com/ask/639354
问题二:命令中应如何复用argv参数?
命令中应如何复用argv参数?
参考回答:
命令传入的argv参数类型为RedisModuleString **,这些RedisModuleString在命令返回后会被自动释放。因此,在命令中不应该直接引用这些RedisModuleString指针。如果确实需要复用这些参数,以避免内存拷贝,可以使用RedisModule_RetainString或RedisModule_HoldString增加该RedisModuleString的引用计数。但请注意,之后必须手动释放这些字符串,以避免内存泄漏。
关于本问题的更多回答可点击原文查看:
https://developer.aliyun.com/ask/639355
问题三:在使用RedisModule_OpenKey打开一个key时,为什么要严格区分打开的类型?
在使用RedisModule_OpenKey打开一个key时,为什么要严格区分打开的类型?
参考回答:
在使用RedisModule_OpenKey打开一个key时,严格区分打开的类型(如REDISMODULE_READ、REDISMODULE_WRITE)非常重要。这影响着是否更新内部的stat_keyspace_misses和stat_keyspace_hits信息,还影响了过期再写入的问题。同时,以REDISMODULE_READ方式打开的key不能被删除,否则会导致错误。
关于本问题的更多回答可点击原文查看:
https://developer.aliyun.com/ask/639356
问题四:遇到key存在但类型不匹配时应如何处理?
遇到key存在但类型不匹配时应如何处理?
参考回答:
目前只有string类型的set命令可以强行覆盖其他类型的key。其他的命令在遇到key存在但类型不匹配时,应返回错误消息,如""WRONGTYPE Operation against a key holding the wrong kind of value",以提示用户操作无效。
关于本问题的更多回答可点击原文查看:
https://developer.aliyun.com/ask/639357
问题五:多key命令在cluster模式下应如何处理?
多key命令在cluster模式下应如何处理?
参考回答:
对于多key的命令,在cluster模式下,必须正确处理firstkey、lastkey、keystep这三个值。只有这三个值设置正确,Redis才会去检查这些key是否存在CROSS SLOTS的问题,即这些key是否分布在不同的槽位中,这是Redis Cluster正常工作的基础。
关于本问题的更多回答可点击原文查看: