redis的数据类型

简单介绍一下redis的几种数据类型: StringsListsSetsHasheSorted setsBitmaps and HyperLogLogs

Strings

Strings是redis的最基础的类型,意味着reds stings可以包含任何数据类型,普通的string,integer…自不必说,JPEG 图片,Java对象,文件等等都可以序列化成strings。

最大限制:512M

常用操作:

其他: available string commands

Lists

Redis Lists是strings的集合list,顺序为元素的插入顺序。当然也可以通过命令在head或者tail插入元素。即使list很大,在head或者tail增删元素的速度也很快,但是如果操作中间的元素,则复杂度为O(N)。

lists最大长度: 2^32 - 1 (4294967295, 也就是每个list可以存40亿个元素)

有意思的案例:

  • 创建设计网络中的时间线,使用 LPUSH 增加元素,而使用LRANGE获取最新插入的几个元素
  • 使用 LPUSHLTRIM 创建一个固定容量的list,只记录最新的几个元素
  • 使用list结构创建一个消息队列,如ruby的Resque - 用于创建后台任务
  • BLPOP

其他: available commands operating on lists

Sets

Redis Sets是strings的无序无重复集合。增删查的复杂度是0(1),基于sets可以做 unions, intersections 等操作

sets最大长度: 2^32 - 1 (4294967295, 也就是每个set可以存40亿个元素)

一些案例:

  • trace 一些唯一事件,比如说记录一篇blog的访问ip,仅仅只需要使用 SADD ,而不需要考虑是否重复。
  • 创建一个标签系统,给对象标记不同的tag
  • 使用 SPOP 或者 SRANDMEMBER 命令从一个set中随机抽取元素
  • 其他: full list of Set commands

Hashes

Redis Hashes 是用来存储一些键值对的,举个栗子:

1
2
3
4
5
@cli
HMSET user:1000 username antirez password P1pp0 age 34
HGETALL user:1000
HSET user:1000 password 12345
HGETALL user:1000

每一个hash都可以存储至多 2^32 - 1个 键值对

其他: full list of Hash commands

Sorted sets

redis Sorted Sets 和sets类型相似,但最大的不同点是 Sorted Set 的每一个元素都有一个分值,这个分值可以用作排序,虽然元素是不重复的,但分值可能相同。可以获取不同分值段内的一些元素。

sorted sets 可以做很多有意思的事情,与直接操作数据库相比,有很好的性能

  • 比如设计一个在线游戏的选手积分榜,使用ZADD来增加一个新的记录,使用 ZRANGE 获取前几名的选手,也可以使用 ZRANGE来获取一个选手的排名。使用ZRANK 和 ZRANGE可以很快查询到一个元素附近的几个元素
  • Sorted Sets常常被用来做作redis中的索引数据,比如有很多用户的hash数据,可以使用用户的年龄作为分值,用户id作为值,使用ZRANGEBYSCORE就可以很快查询出一个年龄区间内的用户

其他:full list of Sorted Set commands

Bitmaps and HyperLogLogs

Redis 同时也支持Bitmaps 和 HyperLogLogs,基于Strings实现,但有他们自己的语义。

其他:introduction to Redis data types

推荐的redisdocs:

References

Data types