• Redis集群报错:(error) CROSSSLOT Keys in request don't hash to the same slot 的解决办法


    Redis 哈希槽基本概念

    哈希槽(hash slot)是来自Redis Cluster的概念, 但在各种集群方案都有使用。

    哈希槽是一个key的集合,Redis集群共有16384个哈希槽,每个key通过CRC16散列然后对16384进行取模来决定该key应当被放到哪个槽中,集群中的每个节点负责一部分哈希槽。

    以有三个节点的集群为例:

        节点A包含0到5500号哈希槽
        节点B包含5501到11000号哈希槽
        节点C包含11001到16384号哈希槽
        这样的设计有利于对集群进行横向伸缩,若要添加或移除节点只需要将该节点上的槽转移到其它节点即可。

    在某些集群方案中,涉及多个key的操作会被限制在一个slot中,如Redis Cluster中的mget/mset操作。
    HashTag

    HashTag机制可以影响key被分配到的slot,从而可以使用那些被限制在slot中操作。

    HashTag即是用{}包裹key的一个子串,如{user:}1, {user:}2。

    在设置了HashTag的情况下,集群会根据HashTag决定key分配到的slot, 两个key拥有相同的HashTag:{user:}, 它们会被分配到同一个slot,允许我们使用MGET命令。

    通常情况下,HashTag不支持嵌套,即将第一个{和第一个}中间的内容作为HashTag。若花括号中不包含任何内容则会对整个key进行散列,如{}user:。

    HashTag可能会使过多的key分配到同一个slot中,造成数据倾斜影响系统的吞吐量,务必谨慎使用。
    mset在集群模式设置值时错误 CROSSSLOT Keys in request don’t hash to the same slot

     解决方案HashTag

    HashTag即是用{}包裹key的一个子串,如{user:}1, {user:}2。



  • 相关阅读:
    深入学习SlidingMenu 2015-06-12 20:27 856人阅读 评论(0) 收藏
    Android 判断SD卡是否存在及容量查询
    第三方登录,授权,分享
    GLSurfaceView用法详解
    Java/android面试题
    SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问
    填充数字以达到位数
    web api post
    .net测试方法效率获取系统当前时间
    vs2012更新问题
  • 原文地址:https://www.cnblogs.com/zouhong/p/16439487.html
Copyright © 2020-2023  润新知