初识redis的编码方式

使用type命令返回的是当前key对应的value的数据结构类型,例如:string(字符串), list(列表),hash(哈希),set(集合),zset(有序集合)。这些只是redis对外的数据结构,

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

:::info

数据结构:value的数据类型

编码方式:底层实现value这种数据结构的方式

:::
Redis数据结构和内部编码

  1. string类型
    1. 当value是一个整数时,此时redis会直接使用int来保存
    2. 当value字符串长度较短时,string的底层是embstr
    3. 当string字符串较长时,string底层采用raw(在java中就是byte数组)
  2. hash类型
    1. hashtable就是哈希表,注意不是java标准库中的hashtable
    2. ziplist压缩列表,当哈希表中元素较少时优化成ziplist,节省空间。
      1. 为什么需要压缩:redis上有很多很多的key,某些key对应的value类型是hash,如果key非常多,对应的hash也特别多,但是每个hash又不大的情况下,就去压缩,让整体占用的内存更小。
  3. list类型
    1. linkedlist就是链表
    2. ziplist压缩列表
    3. 在redis3以后采用quicklist,同时兼顾linkedlist和ziplist的优点,quicklist是一个链表,链表上每个节点又是一个ziplist,把空间和效率都兼顾到。
  4. set类型
    1. hashtable哈希表
    2. intset集合里存的都是整数
  5. zset类型
    1. skiplist 跳表也是链表,不同的地方是,每个节点上有多个指针域,巧妙的搭配这些指针域的指向,能做到查询元素的时间复杂度是O(logN)
    2. ziplist压缩列表

咱们可以通过object encoding key命令查询value的内部编码

相关推荐
heartbeat..3 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
麦聪聊数据5 小时前
MySQL并发与锁:从“防止超卖”到排查“死锁”
数据库·sql·mysql
AC赳赳老秦6 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek
YMatrix 官方技术社区7 小时前
YMatrix 存储引擎解密:MARS3 存储引擎如何超越传统行存、列存实现“时序+分析“场景性能大幅提升?
开发语言·数据库·时序数据库·数据库架构·智慧工厂·存储引擎·ymatrix
辞砚技术录8 小时前
MySQL面试题——索引2nd
数据库·mysql·面试
linweidong8 小时前
C++thread pool(线程池)设计应关注哪些扩展性问题?
java·数据库·c++
欧亚学术9 小时前
突发!刚刚新增17本期刊被剔除!
数据库·论文·sci·期刊·博士·scopus·发表
黑白极客9 小时前
怎么给字符串字段加索引?日志系统 一条更新语句是怎么执行的
java·数据库·sql·mysql·引擎
码农水水9 小时前
中国邮政Java面试:热点Key的探测和本地缓存方案
java·开发语言·windows·缓存·面试·职场和发展·kafka
大厂技术总监下海9 小时前
数据湖加速、实时数仓、统一查询层:Apache Doris 如何成为现代数据架构的“高性能中枢”?
大数据·数据库·算法·apache