【Redis】数据结构和内部编码

数据结构和内部编码

type 命令实际返回的就是当前键的数据结构类型,它们分别是:string(字符串)、list(列表)、hash(哈希)、set(集合)、zset(有序集合),但这些只是 Redis 对外的数据结构.

实际上Redis内部针对每个数据结构都有自己的内部编码, 而且是多种实现, 这样Redis会在合适的场景选择合适的内部编码

可以看到每种数据结构都有⾄少两种以上的内部编码实现,例如 list 数据结构包含了 linkedlist 和ziplist 两种内部编码。同时有些内部编码,例如 ziplist,可以作为多种数据结构的内部实现,可以通过 object encoding 命令查询内部编码:

可以看到 hello 对应值的内部编码是 embstr,键 mylist 对应值的内部编码是 ziplist。

Redis 这样设计有两个好处:

  1. 可以改进内部编码, 而对外的数据结构和命令没有任何影响, 这样一旦开发出更优秀的内部编码, 无需改动外部数据结构和命令, 例如Redis 3.2 提供了 quicklist, 结合了 ziplist 和linkedlist 两者的优势, 为列表类型提供了一种更为优秀的内部编码实现, 而对用户来说基本无感知.

  2. 多种内部编码实现可以在不同场景下发挥各自的优势, 例如 ziplist 比较节省内存, 但是在列表元素比较多的情况下, 性能会下降, 这时候 Redis 会根据配置选项将列表类型的内部实现转化为 Linkedlist, 整个过程用户同样无感知.

相关推荐
醉卧考场君莫笑1 分钟前
SQL查询基础
数据库·sql·oracle
三万棵雪松3 分钟前
【AI小智后端部分(五)】
数据库·人工智能·python·语音处理·ai小智
萧曵 丶8 分钟前
MySQL加索引会不会导致数据库锁表?
数据库
lllsure10 分钟前
【MySQL】读写分离
数据库·mysql
胖咕噜的稞达鸭13 分钟前
Linux系统编程:文件系统(CHS LBA地址,Block Group 软硬连接,手搓简化版本的FILE结构体)
android·linux·数据库
gjc59213 分钟前
数据库和缓存稳定性保障-扩容及升级规范
java·开发语言·数据库·缓存
图南随笔21 分钟前
Spring Boot(二十四):Redis几种数据类型的适用场景对比
java·spring boot·redis
松涛和鸣21 分钟前
DAY 44 HTML and HTTP Server Interaction Notes
linux·前端·网络·数据库·http·sqlite·html
Mr.Entropy24 分钟前
Mysql和PostgreSQL详细对比
数据库·mysql·postgresql
GottdesKrieges24 分钟前
OceanBase数据库全链路追踪
数据库·oceanbase