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

posted @ 2021-01-11 10:44  天明听歌  阅读(5785)  评论(0编辑  收藏  举报