为啥redis集群的最大槽数是16384个?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥redis集群的最大槽数是16384个?相关的知识,希望对你有一定的参考价值。

参考技术A 在redis节点发送心跳包时需要把所有的槽放到这个心跳包里,以便让节点知道当前集群信息,16384=16k,在发送心跳包时使用 char 进行bitmap压缩后是2k( 2 * 8 (8 bit) * 1024(1k) = 16K ),也就是说使用2k的空间创建了16k的槽数。

虽然使用CRC16算法最多可以分配65535(2^16-1)个槽位,65535=65k,压缩后就是8k( 8 * 8 (8 bit) * 1024(1k) =65K ),也就是说需要需要8k的心跳包,作者认为这样做不太值得;并且一般情况下一个redis集群不会有超过1000个master节点,所以16k的槽位是个比较合适的选择。

redis集群配置为啥用自身ip会超时换成127.0.0.1就可以了?

../redis-cli --cluster create 135.215.24.125:7991 135.215.24.125:7992 135.215.24.125:7993 --cluster-replicas 1 -a xxxx
这样说连接超时,把上面ip换成127.0.0.1就能构建成功了,我的bind注释了,保护模式也设置为no了

    查看进程 ps -ef | grep redis进程中会显示你监听的地址如果是0.0.0.0说明任意地址都可以连接如果是127.0.0.1说明只有本地才可连接,使用局域网地址不行修改配置文件后,需要重启才生效希望可以帮助你,请采纳,谢谢
参考技术A 所有的设备都使用127.0.0.1这个ip代表本地ip使用,不对外发布追问

可是不改ip,springboot就连接不上啊

以上是关于为啥redis集群的最大槽数是16384个?的主要内容,如果未能解决你的问题,请参考以下文章

redis集群的插槽问啥是16384个

redis集群的插槽问啥是16384个

redis最大多少个节点问题

Redis客户端集群

redis集群

Redis官方解答为啥Redis Cluster设计成16384个槽?