一、压缩列表ziplist
压缩列表(ziplist)是由 一系列特殊编码的内存块构成的列表,其是Redis的列表建和哈希键的底层实现之一。和整数集合一样,二者都是为Redis节省内存而开发的数据结构。
ziplist可以用来存放字符串或者整数,其存储数据的特点是:比较小的整数或比较短的字符串。
当list键里包含的元素较少、并且每个元素要么是小整数要么是长度较小的字符串时,redis将会用ziplist作为list键的底层实现。同理hash和zset在这种场景下也会使用ziplist。
下图是不同数据结构的实现:
二、有海量key和value都比较小的数据,在redis中如何存储才更省内存
通过大幅减少key的数量来降低内存的消耗。
通过hash hset,在客户端通过分组将海量的key根据一定的策略映射到一组hash对象中,由于value较小,故hash类型的对象会使用占用内存较小的ziplist编码。
eg:如存在100万个键,可以映射到1000个hash中,每个hash保存1000个元素。