Redis教程

Redis - 为什么redis集群的最大槽数是16384个?

本文主要是介绍Redis - 为什么redis集群的最大槽数是16384个?,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

为什么是16384(2^14)个?

在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的槽位是个比较合适的选择。

参考文献

作者:泰迪的bagwell
链接:https://www.jianshu.com/p/de268f62f99b
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
这篇关于Redis - 为什么redis集群的最大槽数是16384个?的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!