Redis 内存占用量估算


string类型的内存大小 = 键值个数 * (dictEntry大小 + redisObject大小 + 包含key的sds大小 + 包含value的sds大小) + bucket个数 * 4

注意如果key或者value的字符串长度+9字节超过16字节,则实际申请的内存大小32字节.

如果key或者value的字符串长度+9字节超过16字节,则实际申请的内存大小32字节

对于1w个key如果rehash过后就需要16384个bucket.

下面是我们的预估值,100万来算,key的sds大小为32,value的sds大小为32

1000000 * (16 + 16 + 32 + 32) + 1638400 * 4 = 102,553,600

1G内存为1073741824字节,so 100万条大概是 100M 内存

没有实际测算,只是根据下面参考算了下

参考:https://www.oschina.net/question/12_31910


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM