redis 中 zset 的数据存储方式

zset 是 redis 的一种数据存储方式,所存储的数据是有序的、唯一的。zset由两种存储方式转换对数据进行存储,分别是 ziplist(压缩表)和 skiplist(跳表)。

当成员数量 <= zset-max-ziplist-entries(默认128)值并且成员长度 <= zset-max-ziplist-value(默认64)值时,采用压缩表的方式存储,压缩表是一个升级的数组,每一个位置除了保存数据外,还包含了数组长度、数组首位元素的元信息,这样就可以快速定位到数组的首尾节点。

当不满足上述任何一个条件时,zset的存储方式由 ziplist 转为 skiplist 。skiplist是以链表的方式顺序存储,在该模式下,skiplist 搭配 Hash Table(哈希表)一起使用,通过搭配哈希表实现快速访问单个成员、保证成员唯一性、数据有序、范围查询等功能,skiplist 天然的数据结构保证数据有序,同时还能实现范围查询;哈希表实现快速访问(通过链表访问数据的话,需要逐个查询,而哈希表通过映射链表的值,可以实现O(1)复杂度访问成员)。

双存储方式的转换,能够极大地提高数据存取效率,在数据内存较小的情况下以数组的方式存储,数组占用内存紧凑,数据读取方便,数据的操作造成的性能影响也可以接受;当数据内存大的时候,如果继续采用数组的方式,数据操作的效率就会不断降低,转为跳表的存储方式,牺牲内存换取高效查询和范围操作。

zset 的存储方式初始是 ziplist 形式,当转为 skiplist 形式后将一直持续以该方法存储。

相关推荐
天上掉下来个程小白2 小时前
缓存套餐-03.功能测试
redis·缓存·springboot·苍穹外卖·springcache
敖行客 Allthinker3 小时前
Redis 重回开源怀抱:开源精神的回归与未来展望
数据库·redis·开源
临界点oc8 小时前
Redis从入门到实战 - 高级篇(上)
数据库·redis·缓存
小马爱打代码12 小时前
Nginx+Lua+Redis实现灰度发布
redis·nginx·lua
dancing99913 小时前
linux下的Redis的编译安装与配置
linux·运维·redis
Aliano21717 小时前
Pinecone向量库 VS Redis
数据库·redis·缓存·pinecone向量库
Aric_Jones1 天前
FastDFS,分布式文件存储系统,介绍+配置+工具类
java·数据库·redis·分布式·idea·dfs
中草药z1 天前
【Redis】哨兵机制和集群
数据库·redis·缓存·集群·cluster·哨兵·数据分区算法
邪恶的贝利亚1 天前
redis大全
数据库·redis·bootstrap
zizisuo1 天前
2.Redis高阶实战
数据库·redis·缓存