redis的数据类型
简单介绍一下redis的几种数据类型: Strings,Lists,Sets, Hashe,Sorted sets,Bitmaps and HyperLogLogs
Strings
Strings是redis的最基础的类型,意味着reds stings可以包含任何数据类型,普通的string,integer…自不必说,JPEG 图片,Java对象,文件等等都可以序列化成strings。
最大限制:512M
常用操作:
- INCR, DECR, INCRBY:通过strings实现原子化操作
- APPEND:改变字符串
- GETRANGE , SETRANGE: 自由获取或者变更Strings
- GETBIT, SETBIT:对Strings进行位操作,如通过redis创建一个bloom filter
Lists
Redis Lists是strings的集合list,顺序为元素的插入顺序。当然也可以通过命令在head或者tail插入元素。即使list很大,在head或者tail增删元素的速度也很快,但是如果操作中间的元素,则复杂度为O(N)。
lists最大长度: 2^32 - 1 (4294967295, 也就是每个list可以存40亿个元素)
有意思的案例:
- 创建设计网络中的时间线,使用 LPUSH 增加元素,而使用LRANGE获取最新插入的几个元素
- 使用 LPUSH 和 LTRIM 创建一个固定容量的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 | @cli |
每一个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