Redis常用数据类型底层数据结构分析

Redis是一种键值(key-Value)数据库,相对于关系型数据库,它也被叫作非关系型数据库

Redis中,键的数据类型是字符串,但是为了非富数据存储方式,方便开发者使用,值的数据类型有很多

字符串 (string)

这种数据类型非常简单,对应到数据结构里面,就是字符串

列表 (list)

支持存储一组数据,这种数据类型对应两种方式,一种是压缩列表,另一种是双向循环链表

## 压缩列表 
  • 列表中保存的单个数据小于64字节
  • 列表数据个数少于512个

    比较省内存,支持不同类型数据的存储

    链表

Reis的双向链表额外定义了一个list结构体,来组织链表的首、尾指针,还有长度等信息

字典 (hash)

存储一组数据对。每个数据对又包含键值两部分,实现方式压缩列表散列表

## 压缩列表
  • 字典中保存的键和值的大小都要小于64字节
  • 字典中键值对的个数要小于512个

    散列表

使用 MurmurHash2运行速度快、随机性好的哈希算法作为哈希函数,对于哈希冲突问题,Redis使用链表法来解决。除此之外,
Redis还支持散列表的动态扩容、缩容。

  • 装载因子 > 1 -->扩大2倍
  • 装载因子 <0.1 -->缩小2倍

集合 (set)

集合用来存储一组不重复的数据,也有两种实现,一种是有序数组,一种是散列表
## 有序数组

  • 存储的数据都是整数。
  • 存储的数据元素个数不超过512个。

有序集合 (sortedset)

存储一组数据,并且每个数据会附带一个得分。通过得分的大小,将数据组织成跳表这样的数据结构,以支持快速地按照得分值、得分区间获取数据

posted @ 2019-11-05 10:54  james_cai  阅读(376)  评论(0)    收藏  举报