使用Python操做Redis

首先安装pippython

 

 

也可使用easy_install的方式来安装:git

 

 

 

或者直接编译安装:github

 

 

 

2 . 简单的redis操做

redis链接实例是线程安全的,能够直接将redis链接实例设置为一个全局变量,直接使用。若是须要另外一个Redis实例(or Redis数据库)时,就须要从新建立redis链接实例来获取一个新的链接。同理,python的redis没有实现select命令。redis

 

 

3. pipeline操做

管道(pipeline)是redis在提供单个请求中缓冲多条服务器命令的基类的子类。它经过减小服务器-客户端之间反复的TCP数据库包,从而大大提升了执行批量命令的功能。数据库

 

 

管道的命令能够写在一块儿,如:flask

 

 

默认的状况下,管道里执行的命令能够保证执行的原子性,执行pipe = r.pipeline(transaction=False)能够禁用这一特性。安全

4. 应用场景 – 页面点击数

《Redis Cookbook》对这个经典场景进行详细描述。假定咱们对一系列页面须要记录点击次数。例如论坛的每一个帖子都要记录点击次数,而点击次数比回帖的次数的多得多。若是使用关系数据库来存储点击,可能存在大量的行级锁争用。因此,点击数的增长使用redis的INCR命令最好不过了。
当redis服务器启动时,能够从关系数据库读入点击数的初始值(1237这个页面被访问了34634次)服务器

 

 

每当有一个页面点击,则使用INCR增长点击数便可。app

 

 

页面载入的时候则可直接获取这个值网站

 

 

5. 使用hash类型保存多样化对象

当有大量类型文档的对象,文档的内容都不同时,(即“表”没有固定的列),可使用hash来表达。

 

 

6. 应用场景 – 社交圈子数据

在社交网站中,每个圈子(circle)都有本身的用户群。经过圈子能够找到有共同特征(好比某一体育活动、游戏、电影等爱好者)的人。当一个用户加入一个或几个圈子后,系统能够向这个用户推荐圈子中的人。
咱们定义这样两个圈子,并加入一些圈子成员。

 

 

#得到某一圈子的成员

 

 

可使用集合运算来获得几个圈子的共同成员:

 

 

7. 应用场景 – 实时用户统计

Counting Online Users with Redis介绍了这个方法。当咱们须要在页面上显示当前的在线用户时,就可使用Redis来完成了。首先得到当前时间(以Unix timestamps方式)除以60,能够基于这个值建立一个key。而后添加用户到这个集合中。当超过你设定的最大的超时时间,则将这个集合设为过时;而当须要查询当前在线用户的时候,则将最后N分钟的集合交集在一块儿便可。因为redis链接对象是线程安全的,因此能够直接使用一个全局变量来表示。

 

相关文章
相关标签/搜索