[关闭]
@a5635268 2017-06-25T17:39:54.000000Z 字数 1837 阅读 1308

【redis专题(11)】redis的应用场景

Redis


不同数据类型的内存管理介绍

03152154_EKe5.jpg-22kB

如上图所示,首先Redis内部使用一个redisObject对象来表示所有的key和value,redisObject最主要的信息如上图所示:type 代表一个value对象具体是何种数据类型,encoding是不同数据类型在redis内部的存储方式,比如:type=string代表value存储的是一个普通字符串,那么对应的encoding可以是raw或者是int,如果是int则代表实际redis内部是按数值型类存储和表示这个字符串的,当然前提是这个字符串本身可以用数值表示,比如:"123" "456"这样的字符串。

我们可以发现Redis使用redisObject来表示所有的key/value数据是比较浪费内存的,当然这些内存管理成本的付出主要也是为了给Redis不同数据类型提供一个统一的管理接口。

不同的数据类型对应的使用场景

string

规定某个key值在某段时间内只能出现一次

  1. function redisLock($syncKey,$expire=1000){
  2. if (!$this->redis->setnx ( $syncKey, 1 )) {
  3. return false;
  4. }
  5. $this->redis->pexpire($syncKey, $expire);
  6. return true;
  7. }

Redis的命令都是原子性的,你可以轻松地利用INCR,DECR命令来构建计数器系统。

Hash

在 Memcached 中,我们经常将一些结构化的信息打包成 hashmap,在客户端序列化后存储为一个字符串的值(一般是 JSON 格式),比如用户的昵称、年龄、性别、积分等。这时候在需要修改其中某一项时,通常需要将字符串(JSON)取出来,然后进行反序列化,修改某一项的值,再序列化成字符串(JSON)存储回去。简单修改一个属性就干这么多事情,消耗必定是很大的,也不适用于一些可能并发操作的场合(比如两个并发的操作都需要修改积分)。而 Redis 的 Hash 结构可以使你像在数据库中 Update一个属性一样只修改某一项属性值。

List

比如处理某篇文章的评论时,我们可以先把最新的评论通过Hash和List的方式来存储;Hash中以ID为键,然后把这个ID存入List中,写定时脚本把冷数据存入数据库。

假设后五千条评论为冷数据,我们将最新的5000条评论从List中取出来:

  1. FUNCTION get_latest_comments(start,num_items):
  2. id_list = redis.lrange("latest.comments",start,start+num_items-1)
  3. IF id_list.length < num_items
  4. id_list = SQL_DB("SELECT ... ORDER BY time LIMIT ...")
  5. END
  6. RETURN id_list
  7. END

zset

排行榜应用

与取最新数据的不同之处在于,前面操作以时间为权重(list就可以满足),这个是以某个条件为权重,比如按顶的次数排序,这时候就需要我们的sorted set出马了,将你要排序的值设置成sorted set的score,将具体的数据设置成相应的value,每次只需要执行一条ZADD命令即可。

构建优先级队列系统

set

数据排重

关于 redis的无序集合有三个特点: 无序性, 确定性(描述准确) , 唯一性。只需要不断地将数据往set中扔,得到的数据肯定是uniq的。

集合应用

Redis 非常人性化的为集合提供了求交集、并集、差集等操作,那么就可以非常方便的实现如共同关注、共同喜好、二度好友等功能,对上面的所有集合操作,你还可以使用不同的命令选择将结果返回给客户端还是存集到一个新的集合中。

Pub/Sub

Pub/Sub构建实时消息系统

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注