版权声明:本文首发 http://asing1elife.com ,转载请注明出处。 https://blog.csdn.net/asing1elife/article/details/82876687
Redis 核心对象是 RedisObject ,下图简单概括了 RedisObject 中的组成部分
更多精彩
- 更多技术博客,请移步 asing1elife’s blog
数据模型图
数据类型
String
- 常用命令为 set / get / decr / incr / mget
- 最常用的数据类型,普通的 key-value 存储都会被归为此类
- 在 Redis 内存存储默认是一个字符串,被 redisObject 引用
- 当遇到 decr / incr 操作时会转成数值型进行计算(前提是可以计算),此时 redisObject 中的 encoding 为 int
Hash
- 常用命令为 hget / hset / hgetall
- 用于存储复杂的对象数据,实现方式为 key-hash[field-value] ,其对应的 value 实际上是一个 HashMap
- 当数据较少时,Redis 并不会采用真正意义上的 HashMap 存储 value ,其在 redisObject 中对应的 encoding 实际上是 zipmap ,类似一维数组
- 当数据较多时,才会使用 HashMap ,其在 redisObject 中对应的 encoding 是 ht
List
- 常用命令为 lpush / rpush / lpop / rpop / lrange
- 最重要的数据类型之一,用于存放列表数据
- 与 Hash 类似,当数据较少时使用 ziplist 存值,反之则使用 List
- Redis 中的 List 是一个双向链表,可支持反响查找和遍历
- Redis 内部很多实现,例如发送缓冲队列用的就是该数据结构
Set
- 常用命令为 sadd / spop / smembers / sunion
- 与 List 类似同样用于存放列表数据,但其优势在于快速去重
- 可判断某个对象是否存在与 Set 中
- 实际上是一个 value 用于为 null 的 HashMap ,通过计算 hash 来实现快速去重,以及判断对象是否存在也是依赖于此
Sorted Set
- 常用命令为 zadd / zrange / zrem / zcard
- 相较于 Set ,Sorted Set 的优势在于自动排序,可实现一个有序且不重复的列表
- 其可以额外的优先级[Score]参数为成员排序
- 内部使用 HashMap 和 SkipList(跳跃表)来保证数据的存储去重和有序
- HashMap 中存放成员到 score 的映射,SkipList 中存放所有成员,排序依据是 HashMap 中存放的 score