Redis 底层数据结构介绍

栏目: 数据库 · 发布时间: 4年前

内容简介:版本:2.9支持的数据类型:

Redis 底层数据结构介绍

Redis 底层数据结构

版本:2.9

支持的数据类型:

  1. 字符串
  2. 散列
  3. 列表
  4. 集合
  5. 有序集合

字符串

Redis 利用原生的 c 字符串进行了一次封装。封装的字符串叫做简单动态字符串:SDS(simple dynamic string)

Redis 使用的简单动态字符串比 c 语言原生的字符串有以下优点:

  1. 获取字符串长度的复杂度为O(1)
  2. 不存在缓存区溢出
  3. 修改字符串长度时,不需要频繁分配内存
  4. 空间预分配策略
  5. 惰性空间策略
  6. 二进制安全
  7. 二进制安全的意思是,可以将二进制数据使用 SDS 存储,而不会存在 c 语言中,遇到 \0 是字符串结尾的情况。
  8. 兼容部分 c 字符串函数
  9. 因为 SDS 遵循 c 语言以 \0 结尾的惯例,所以 SDS 可以使用 <string.h> 函数库,避免了重复代码

链表

链表作为最常用的数据结构之一,在 redis 中的使用场景是很多的,其中包括:

  1. 发布、订阅
  2. 列表键
  3. 慢查询
  4. 监视器
  5. 多个客户端状态
  6. 客户端缓冲区

Redis 中链表的几个特性:

  1. 双向链表
  2. 无环
  3. 有表头和表尾指针
  4. 有链表长度计数器
  5. 多态(可以用来保存不同类型的值)

字典

字典又叫符号表,在 PHP 中叫关联数组,在 JAVA 中叫映射(map),在 Python 中叫字典(dict)。别管这么多叫法,字典就是一种保存键值对的一种数据结构。

使用场景

  1. 散列(hash)
  2. Redis 数据库

字典实现

Redis 使用 c 语言构建了自己的字典实现。hash 算法使用的是 murmurhash3 算法。遇到键的 hash 值冲突使用的解决方法是链地址法。当需要扩展时,Redis 利用两个哈希表进行渐进式的 rehash。

字典(内部的哈希表)扩展与收缩条件

哈希表内部会通过公式计算一个负载因子。公式为:

load_factor=ht[0].used/ht[0].Size

扩展条件:

  1. 服务器目前没有在执行 BGSAVE 命令或者 BGREWRITEAOF 命令,并且哈希表的负载因子大于等于1。
  2. 服务器目前正在执行 BGSAVE 命令或者 BGREWRITEAOF 命令,并且哈希表的负载因子大于等于5。

收缩条件:负载因子小于 0.1

跳跃表

跳跃表的结构:

Redis 底层数据结构介绍

跳跃表是一种对标平衡树的一种数据结构。但是比平衡树更简单、更快速、使用更少空间。所以一般都会使用跳跃表。

跳跃表在 Redis 中的使用场景暂时仅限于实现有序集合。

跳跃表的实现参见: http://blog.jobbole.com/111731/

整数集合

整数集合的使用场景为元素不多且只包含整数元素的集合。

使用 c 数组实现。

压缩列表(ziplist)

压缩列表是 Redis 为了节省内存实现的。当列表键和哈希键的项比较少,并且存储的值比较小时,会使用压缩列表节省内存。

Redis 底层数据结构介绍

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

一个APP的诞生

一个APP的诞生

Carol 炒炒、刘焯琛 / 电子工业出版社 / 2016-7-1 / 79

在移动互联网高度发达的今天,一个个APP,成为我们通向网络世界的窗口。它的诞生流程,令不少对互联网世界产生幻想甚至试图投身其中的年轻人充满了好奇。 《一个APP 的诞生》就是这样一步一步拆分一个APP 的诞生过程。从前期市场调研,竞品分析开始,一直到设计规范,界面图标,设计基础,流程管理,开发实现,市场推广,服务设计,甚至跨界融合,都有陈述。 《一个APP 的诞生》被定义是一本教科书,......一起来看看 《一个APP的诞生》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

随机密码生成器
随机密码生成器

多种字符组合密码