redis数据库

Redis中String和Hash哪个结构更加省内存

2022-04-18  本文已影响0人  小胖学编程

简略答案:在Redis的hash结构使用ziplist编码且存储相同信息时,hash结构比sring结构更加节省内存。

1. 分析:谁更加节省内存

string结构:

可以简单任务Redis的String结构是用SDS(简单动态字符串)数据结构来实现的。

SDS结构.png

hash结构使用ziplist结构时:

ziplist结构.png

ziplist最大的特点就是,他不是hashtable结构,而是一个比较长的字符串,将key-value都按照顺序依次摆放到一个长长的字符串里来存储。如果要找某个key,就需要遍历整个长字符串。

原因:使用string存储数据时,每一个记录都是一个SDS都需要存在len、free来标识。但是使用hash的ziplist时,只需要标头的几个标识位外,接着都是紧凑的数据。这就是为什么hash(ziplist)比string更节省内存的原因。

2. Redis如何存储hash

2.1 hash的两种结构

hash数据结构,在编码方式上有两种,1是hashTable,2是zipList。

换句话说,zipList比起hashTable占用的空间少,但是会耗费更多cpu来进行查询。

2.2 hash两种结构的使用时机

  1. 当hash结构的内层field-value数量不超过512。
  2. 并且value字节数不超过64时,就使用zipList。

经过实测,value数量在512时,性能和单纯的hashTable几乎无差别,在value数量不超过1024时,性能仅有极小的降低,可以忽略。

而内存占用,zipList比hashTable降低极多。

推荐阅读

redis中为什么hash比string做缓存更节省内存与效率更高? - 像灭霸一样看日出 - 程序员ITS500

选择合适Redis数据结构,减少80%的内存占用

redis string底层数据结构

上一篇下一篇

猜你喜欢

热点阅读