Redis 常见的数据类型有5种:string、list、set、sorted set、hash
类型 | 最大存储数据量 |
string(字符串) | 512M |
list(列表) | 2^32-1 |
set(集合) | 2^32-1 |
sorted set(Zset有序集合) | 2^32-1 |
hash(哈希) | 2^32-1 |
String(字符串)
介绍:string 数据结构是简单的 key-value 类型,最常规的set/get操作,value可以是String也可以是数字,二进制安全的字符串,一个键最大能存储512M。
使用场景:一般常用在需要复杂计数的场景,比如用户的访问次数、热点文章的点赞转发数量等等。
key/value:二进制安全的。意思是 redis 的 string 可以包含任何数据。比如 jpg 图片或者序列化的对象。
list(列表)
介绍:list 即是 链表。按照添加顺序保持顺序的字符串列表。
使用场景:发布与订阅、消息队列、慢查询、简单的字符串列表、关注列表。可以做简单的消息队列的功能。另外还有一个就是,可以利用lrange命令,做基于redis的分页功能,性能极佳,用户体验好。本人还用一个场景,很合适—取行情信息。就也是个生产者和消费者的场景。List可以很好的完成排队,先进先出的原则。
hash(哈希)
介绍:hash 类似于 JDK1.8 前的 HashMap,内部实现也差不多(数组 + 链表)。
使用场景:存储对象数据,存储用户信息,以cookieId作为key,设置30分钟为缓存过期时间,能很好的模拟出类似session的效果。
set(集合)
介绍:set 类似于 Java 中的 HashSet 。Redis 中的 set 类型是一种无序集合,集合中的元素没有先后顺序。当你需要存储一个列表数据,又不希望出现重复数据时,set 是一个很好的选择,并且 set 提供了判断某个成员是否在一个 set 集合内的重要接口,这个也是 list 所不能提供的。可以基于 set 轻易实现交集、并集、差集的操作。
使用场景: 需要存放的数据不能重复以及需要获取多个数据源交集和并集等场景、共同关注列表、统计独立 IP。
sorted set(zset:有序集合)
介绍:和 set 相比,sorted set 增加了一个权重参数 score,使得集合中的元素能够按score 进行有序排列,还可以通过 score 的范围来获取元素的列表。有点像是 Java 中 HashMap 和 TreeSet 的结合体。
使用场景:需要对数据根据某个权重进行排序的场景。比如在直播系统中,实时排行信息包含直播间在线用户列表,各种礼物排行榜,弹幕消息(可以理解为按消息维度的消息排行榜)等信息。
每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。