summaryrefslogtreecommitdiff
path: root/redis/crc.py
blob: 7d2ee507bea24a0f3e949722287b7b401ab3d81b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
from binascii import crc_hqx

# Redis Cluster's key space is divided into 16384 slots.
# For more information see: https://github.com/redis/redis/issues/2576
REDIS_CLUSTER_HASH_SLOTS = 16384

__all__ = [
    "key_slot",
    "REDIS_CLUSTER_HASH_SLOTS"
]


def key_slot(key, bucket=REDIS_CLUSTER_HASH_SLOTS):
    """Calculate key slot for a given key.
    See Keys distribution model in https://redis.io/topics/cluster-spec
    :param key - bytes
    :param bucket - int
    """
    start = key.find(b"{")
    if start > -1:
        end = key.find(b"}", start + 1)
        if end > -1 and end != start + 1:
            key = key[start + 1: end]
    return crc_hqx(key, 0) % bucket