返回一个整数,用于标识指定键所散列到的哈希槽。该命令主要用来调试和测试,因为它通过一个API来暴露Redis底层哈希算法的实现。该命令的使用示例:

  1. 客户端库可能会使用Redis来测试他们自己的哈希算法,生成随机的键并且使用他们自己实现的算法和Redis的CLUSTER KEYSLOT命令来散列这些键,然后检查结果是否相同。

  2. 人们会使用这个命令去检查哈希槽是哪个,然后关联Redis Cluster的节点,并且负责一个给定的键。

例如

> CLUSTER KEYSLOT somekey
11058
> CLUSTER KEYSLOT foo{hash_tag}
(integer) 2515
> CLUSTER KEYSLOT bar{hash_tag}
(integer) 2515

注意该命令实现了完整的哈希算法,包括支持 hash tags,这是Redis Cluster键一个特殊的哈希算法,如果键名中存在左右大括号的模式,只会散列在 {} 之间的字符串,为了去强制将多个键由一个节点来处理。

返回值

Integer reply:哈希槽的值。




关于本文翻译者

网名:menwengit
github:menwengit
打赏他
微信