Redis各种数据结构内存占用测试

启动时:(redis为空)

 

插入数据量都为100W(100W个key或者list中100W个值,或者1000个key,每个key中1000个值)

String

Key value

# Memory

used_memory:121763808

used_memory_human:116.12M

used_memory_rss:124956672

used_memory_peak:121762584

used_memory_peak_human:116.12M

used_memory_lua:31744

mem_fragmentation_ratio:1.03

mem_allocator:jemalloc-3.2.0

 

List

Key value如下

# Memory

used_memory:81375240

used_memory_human:77.61M

used_memory_rss:84156416

used_memory_peak:121762496

used_memory_peak_human:116.12M

used_memory_lua:31744

mem_fragmentation_ratio:1.03

mem_allocator:jemalloc-3.2.0

 

Set

Key value

# Memory

used_memory:89764296

used_memory_human:85.61M

used_memory_rss:94650368

used_memory_peak:153269416

used_memory_peak_human:146.17M

used_memory_lua:31744

mem_fragmentation_ratio:1.05

mem_allocator:jemalloc-3.2.0

 

ZSET

# Memory

used_memory:143119144

used_memory_human:136.49M

used_memory_rss:146919424

used_memory_peak:165802136

used_memory_peak_human:158.12M

used_memory_lua:31744

mem_fragmentation_ratio:1.03

mem_allocator:jemalloc-3.2.0

 

Hash

# Memory

used_memory:137763776

used_memory_human:131.38M

used_memory_rss:157798400

used_memory_peak:183714248

used_memory_peak_human:175.20M

used_memory_lua:31744

mem_fragmentation_ratio:1.15

mem_allocator:jemalloc-3.2.0

 

设置:

##ziplist中允许的条目个数

hash-max-ziplist-entries 512

##ziplist中每个条目(K-V)的V允许的最大字节数

hash-max-ziplist-value 64

##如果达到阀值,则重构为hashtable

# Memory

used_memory:21946472

used_memory_human:20.93M

used_memory_rss:25464832

used_memory_peak:183714248

used_memory_peak_human:175.20M

used_memory_lua:31744

mem_fragmentation_ratio:1.16

mem_allocator:jemalloc-3.2.0

 

结论:100W数据在key和value都在10Byte左右时,占用空间100M左右,若使用Hash的压缩列表特性,内存占用减少到1/5.

  100W的key和value都在10Byte时 100w*2*0.00001m=20M

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Redis是一个开源的内存数据存储系统,它支持多种数据结构,包括字符串、哈希表、列表、集合和有序集合。下面是对每种数据结构的简要介绍: 1. 字符串(String):字符串是Redis最基本的数据结构,它可以存储任意类型的数据,比如整数、浮点数、二进制数据等。字符串还支持一些常用的操作,如获取长度、追加、截取等。 2. 哈希表(Hash):哈希表是一种键值对的集合,其中键和值都是字符串类型。哈希表适用于存储对象,可以方便地对对象的属性进行读写操作。常见的操作包括添加字段、获取字段值、删除字段等。 3. 列表(List):列表是一个有序的字符串集合,可以在列表的两端进行元素的插入和删除操作。列表可以用来实现队列、栈等数据结构,还支持一些常用的操作,如获取元素、修改元素、获取子列表等。 4. 集合(Set):集合是一个无序的字符串集合,不允许重复元素。集合支持添加元素、删除元素、判断元素是否存在等操作,还支持求交集、并集、差集等集合运算。 5. 有序集合(Sorted Set):有序集合是一个有序的字符串集合,每个元素都关联着一个分数,可以根据分数对元素进行排序。有序集合支持添加元素、删除元素、根据分数范围获取元素等操作,还支持按照分数进行排名和获取排名范围内的元素。 这些数据结构Redis中都有对应的命令和操作,可以根据具体的需求选择合适的数据结构来存储和操作数据

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值