服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Redis - Redis 哈希Hash底层数据结构详解

Redis 哈希Hash底层数据结构详解

2022-08-03 11:15废物大师兄 Redis

这篇文章主要介绍了Redis 哈希Hash底层数据结构详解的相关资料,需要的朋友可以参考下

1. Redis 底层数据结构

Redis数据库就像是一个哈希表,首先对key进行哈希运算得到哈希值再取模得到一个下标,每个元素是一个节点,节点之间形成链表。这感觉有点像Java中的HashMap。

Redis 哈希Hash底层数据结构详解

不同的数据类型的实现方式是不一样的,可以通过object encoding命令查看底层真正的数据存储结构

Redis 哈希Hash底层数据结构详解

同一种类型在不同的条件下所采用的数据结构也不一样,例如:

Redis 哈希Hash底层数据结构详解

Redis是键值对形式的数据库,key可以是任意值(PS:最终都会转成string),value有多种数据类型

详见:https://redis.io/docs/manual/data-types/data-types-tutorial/

Redis 哈希Hash底层数据结构详解

至此,已经很清楚,hash底层的结构是 ziplist 和 hashtable

那么,什么时候会从ziplist转成hashtable呢?这个在redis.conf中有相关的配置,如下:

Redis 哈希Hash底层数据结构详解

默认情况下:

当ziplist中entry的数量超过512的时候,会转成hashtable 单个元素的值超过64字节的时候,会转成hashtable

2. hashtable

在Redis中hashtable就是字典dict

通过源码,可以看到dict是这样定义的:

Redis 哈希Hash底层数据结构详解

Redis 哈希Hash底层数据结构详解

3. redisDb 与 redisObject

通过源码得知,redisDb代表redis数据库,redisObject代表存到数据库中的数据

Redis 哈希Hash底层数据结构详解

Redis 哈希Hash底层数据结构详解

字典dict的结构前面已经看过了,于是整个数据库的结构大概就是下面这个样子:

Redis 哈希Hash底层数据结构详解

 

4. ziplist

Redis 哈希Hash底层数据结构详解

ziplist是一种特殊编码的双链表,被设计成非常节省内存。它存储字符串和整型值,其中整数被编码为实际整数,而不是一系列字符。它允许在O(1)时间内在列表的任意一边进行push和pop操作。但是,由于每个操作都需要重新分配ziplist所使用的内存,因此实际的复杂性与ziplist所使用的内存量有关。

ziplist的大体布局如下:

<zlbytes> <zltail> <zllen> <entry> <entry> ... <entry> <zlend>

<uint32_t zlbytes>: 一个无符号整数,用于保存ziplist占用的字节数,包括zlbytes字段本身的四个字节。需要存储这个值,以便能够调整整个结构的大小,而不需要首先遍历它。
<uint32_t zltail> : 列表中最后一个条目的偏移量。
<uint16_t zllen>  : 条目的数量。当有超过2^16-2个条目时,这个值被设置为2^16-1,我们需要遍历整个列表来知道它包含多少项。
<uint8_t zlend> : 一个特殊的条目,表示 ziplist 的结尾

Redis 哈希Hash底层数据结构详解

 

5. linkedlist

Redis 哈希Hash底层数据结构详解

Redis 哈希Hash底层数据结构详解

linkedlist是一个双向链表

Redis 哈希Hash底层数据结构详解

 

6. quicklist

Redis 哈希Hash底层数据结构详解

Redis 哈希Hash底层数据结构详解

Redis 哈希Hash底层数据结构详解

quicklistNode是一个32字节的结构体,描述快表的ziplist。

quicklist = linkedlist + ziplist

Redis 哈希Hash底层数据结构详解

到此这篇关于Redis 哈希Hash底层数据结构详解的文章就介绍到这了,更多相关Redis哈希底层数据结构内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文地址:https://www.cnblogs.com/cjsblog/p/16526256.html

延伸 · 阅读

精彩推荐
  • Redis玩转Redis搭建集群之Sentinel详解

    玩转Redis搭建集群之Sentinel详解

    这篇文章主要给大家介绍了关于Redis搭建集群之Sentinel的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需...

    Jackeyzhe2762019-11-20
  • Redis详解缓存穿透击穿雪崩解决方案

    详解缓存穿透击穿雪崩解决方案

    在我们日常的开发中,有时需要系统在极短的时间内完成成千上万次的读/写操作,这个时候不是数据库能够承受的,通常会引入NoSQL技术。redis技术就是N...

    八重樱5532021-08-08
  • Redisredis中使用redis-dump导出、导入、还原数据实例

    redis中使用redis-dump导出、导入、还原数据实例

    这篇文章主要介绍了redis中使用redis-dump导出、导入、还原数据实例,本文直接给出操作命令,并给出注释加以说明,需要的朋友可以参考下 ...

    junjie4142019-10-21
  • Redisredis 限制内存使用大小的实现

    redis 限制内存使用大小的实现

    这篇文章主要介绍了redis 限制内存使用大小的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    四月的水7822021-08-03
  • Redis详解Redis 缓存删除机制(源码解析)

    详解Redis 缓存删除机制(源码解析)

    这篇文章主要介绍了Redis 缓存删除机制(源码解析),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    klew5792021-07-27
  • RedisRedis概述及linux安装redis的详细教程

    Redis概述及linux安装redis的详细教程

    这篇文章主要介绍了Redis概述及linux安装redis的详细教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...

    永不想你11872020-12-28
  • RedisCentOS Linux系统下安装Redis过程和配置参数说明

    CentOS Linux系统下安装Redis过程和配置参数说明

    这篇文章主要介绍了CentOS Linux系统下安装Redis过程和配置参数说明,需要的朋友可以参考下 ...

    junjie5652019-10-21
  • Redisredis简介_动力节点Java学院整理

    redis简介_动力节点Java学院整理

    这篇文章主要介绍了redis简介,Redis是一个开源的,先进的 key-value 存储可用于构建高性能,可扩展的 Web 应用程序的解决方案,有兴趣的可以了解一下 ...

    yiibai3242019-11-07