`

pyredis使用场景

阅读更多

1. 安装pyredis

首先安装pip

 

 

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

 

 

或者直接编译安装:

 

 

 

2 . 简单的redis操作

redis连接实例是线程安全的,可以直接将redis连接实例设置为一个全局变量,直接使用。如果需要另一个Redis实例(or Redis数据库)时,就需要重新创建redis连接实例来获取一个新的连接。同理,python的redis没有实现select命令。

 

 

3. pipeline操作

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

 

 

管道的命令可以写在一起,如:

 

 

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

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

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

 

 

每当有一个页面点击,则使用INCR增加点击数即可。

 

 

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

 

 

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

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

 

 

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

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

 

 

#获得某一圈子的成员

 

 

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

 

 

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

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

 

 

References:

http://blog.csdn.net/vv_demon/article/details/7676384

tigerfish NoSQL和NewSQL数据库引航
《Redis Cookbook》
Redis-Python https://pypi.python.org/pypi/redis/2.9.1

分享到:
评论

相关推荐

    redis入门学习笔记

    Redis是一个开源的、基于内存的数据...总的来说,Redis入门学习笔记详细介绍了Redis的特性、安装、数据类型、使用场景、备份与恢复、性能测试、Python客户端使用等基础知识和技巧,非常适合新手作为入门学习的资料。

    豆瓣电影分析-Python数据分析课设高分项目代码+文档说明

    开发环境说明:该项目在Windows系统中使用Python 3.7.3版本进行开发,其中调用第三方库如Requests、Flask、Pyredis等库完成代理池的开发和维护;结合Requests、BeautifulSoup等第三方库完成电影信息的爬虫任务;利用...

    客户端工具 2020051901.zip

    6. **PyRedis**:Python开发者通常使用PyRedis作为Redis的客户端,它为Python应用程序提供了简单易用的接口来访问Redis服务。 7. **Node.js客户端**:如ioredis或redis模块,这些是Node.js环境下的Redis客户端,使...

    Redis开发相关工具

    - **ioredis**(Java)和**PyRedis**(Python):这两个是编程语言的Redis客户端库,提供了丰富的API供开发者在代码中操作Redis。 2. 使用文档: - **Redis官方文档**:包含了详细的命令参考、最佳实践和配置指南...

    Redis安装包和连接工具.zip

    4. **PyRedis**:Python的Redis客户端,同样提供了丰富的功能,适用于Python开发环境。 5. **Lettuce**:针对Spring框架的Redis客户端,简化了在Spring应用中集成Redis的过程。 连接Redis时,需要知道Redis服务器的...

    Redis客户端连接支持版本2.8+

    2. **PyRedis(Python客户端)**:Python的PyRedis也进行了相应升级,支持连接池和命令管道,同时增加了对Redis 2.8新特性的兼容性,让Python开发者也能享受到这些性能提升。 3. **其他客户端**:诸如Node.js的...

    RealtimeCamera:打开DRUWA-打开深度实时用户欢迎助手

    使用网络摄像头进行实时面部检测和验证。 联络人: 要求 - cmake / gcc,g++ / python 2.7 / pip - CUDA/CUDNN - REDIS Server / hiredis / PyRedis - OpenCV2 or OpenCV3 for support CUDA - Note) You can ...

    redis开发笔记

    Redis支持多种编程语言的客户端库,如Jedis(Java)、PyRedis(Python)、StackExchange.Redis(.NET)等,方便开发者集成到各种项目中。 通过这份"redis开发笔记",你可以深入了解Redis的特性和用法,结合练习...

    shadow-vulscan

    Deployyum install nmap, redis, postgresql10-serverpython3 -m venv venvsource venv\bin\activatepip install -r requirements.txtconfigshadow/config.pyredis: line 25-30postgresql: line 21export FLASK_APP=...

Global site tag (gtag.js) - Google Analytics