1. Redis 底层数据结构

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

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

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

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

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

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

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

默认情况下:

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

2. hashtable

在Redis中hashtable就是字典dict

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

3. redisDb 与 redisObject

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

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

4. ziplist

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 的结尾

5. linkedlist

linkedlist是一个双向链表

6. quicklist

quicklist = linkedlist + ziplist

7. 参考

http://redisbook.com/index.html

http://blog.itpub.net/70000430/viewspace-2787985/

https://www.cnblogs.com/reecelin/p/13358432.html

https://juejin.cn/post/6844904008591605767

最新文章

  1. C#操作XML总结
  2. Windows下安装pip(转自http://www.cnblogs.com/yuanzm/p/4089856.html)
  3. WinForm窗体嵌入
  4. JS怎么动态命名变量名
  5. codeforces 361 D - Friends and Subsequences
  6. js指定标签的id只能添加不能删除
  7. oracle新建用户
  8. kill -9杀掉nginx主进程、reload失败解决办法
  9. Windows下动态库的隐式调用
  10. hdu2089 不要62 我的第一个数位DP
  11. thinkphp框架实现删除上传的文件
  12. css 定位布局
  13. Linux 用户与组
  14. Win10系统的DELL平板如何重装WIN10系统
  15. 【BZOJ4259】残缺的字符串
  16. IEnumerable和IEnumerator接口
  17. 02c语言指针基础
  18. 3G - 汉字统计
  19. oracle怎么恢复被覆盖的存储过程
  20. VC 线程池

热门文章

  1. 三、单redis升级redis集群+哨兵
  2. spring boot redis 写入异常
  3. 设计并实现大数类 BigNum
  4. python之名称空间与函数对象
  5. 编程语言与python与pycharm的下载
  6. 前端CSS3布局display:flex用法
  7. 【题解】Codeforces Round #798 (Div. 2)
  8. ESXI系列问题整理以及记录——使用SSH为设备打VIB驱动包,同时提供一种对于ESXI不兼容螃蟹网卡(Realtek 瑞昱)的问题解决思路
  9. MySQL 8.0 新特性梳理汇总
  10. BUUCTF-ningen