Redis 数据类型

Redis 核心对象是 RedisObject ,下图简单概括了 RedisObject 中的组成部分

数据模型图

数据类型

String

  1. 常用命令为 set / get / decr / incr / mget
  2. 最常用的数据类型,普通的 key-value 存储都会被归为此类
  3. 在 Redis 内存存储默认是一个字符串,被 redisObject 引用
  4. 当遇到 decr / incr 操作时会转成数值型进行计算(前提是可以计算),此时 redisObject 中的 encoding 为 int

Hash

  1. 常用命令为 hget / hset / hgetall
  2. 用于存储复杂的对象数据,实现方式为 key-hash[field-value] ,其对应的 value 实际上是一个 HashMap
  3. 当数据较少时,Redis 并不会采用真正意义上的 HashMap 存储 value ,其在 redisObject 中对应的 encoding 实际上是 zipmap ,类似一维数组
  4. 当数据较多时,才会使用 HashMap ,其在 redisObject 中对应的 encoding 是 ht

List

  1. 常用命令为 lpush / rpush / lpop / rpop / lrange
  2. 最重要的数据类型之一,用于存放列表数据
  3. 与 Hash 类似,当数据较少时使用 ziplist 存值,反之则使用 List
  4. Redis 中的 List 是一个双向链表,可支持反响查找和遍历
  5. Redis 内部很多实现,例如发送缓冲队列用的就是该数据结构

Set

  1. 常用命令为 sadd / spop / smembers / sunion
  2. 与 List 类似同样用于存放列表数据,但其优势在于快速去重
  3. 可判断某个对象是否存在与 Set 中
  4. 实际上是一个 value 用于为 null 的 HashMap ,通过计算 hash 来实现快速去重,以及判断对象是否存在也是依赖于此

Sorted Set

  1. 常用命令为 zadd / zrange / zrem / zcard
  2. 相较于 Set ,Sorted Set 的优势在于自动排序,可实现一个有序且不重复的列表
  3. 其可以额外的优先级[Score]参数为成员排序
  4. 内部使用 HashMap 和 SkipList(跳跃表)来保证数据的存储去重和有序
  5. HashMap 中存放成员到 score 的映射,SkipList 中存放所有成员,排序依据是 HashMap 中存放的 score