使用Python操作Redis应用场景
1. 安装pyredis
首先安装pip
| 1 2 3 4 5 6 7 8 | <SHELL># apt-get install python-pip ...... <SHELL># pip install --proxy=http://172.1.2.6:8080 redis   Downloading redis-2.9.1.tar.gz (62kB): 62kB downloaded   Running setup.py (path:/tmp/pip_build_root/redis/setup.py) egg_info for package redis   ......   Successfully installed redis   Cleaning up... | 
也可以使用easy_install的方式来安装:
| 1 | easy_install redis | 
或者直接编译安装:
| 1 2 3 4 | wget https://pypi.python.org/packages/source/r/redis/redis-2.9.1.tar.gz tar xvzf redis-2.9.1.tar.gz cd redis-2.9.1 python setup.py install | 
2 . 简单的redis操作
redis连接实例是线程安全的,可以直接将redis连接实例设置为一个全局变量,直接使用。如果需要另一个Redis实例(or Redis数据库)时,就需要重新创建redis连接实例来获取一个新的连接。同理,python的redis没有实现select命令。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | >>> import redis >>> r = redis.Redis(host='localhost',port=6379,db=0) >>> r.set('guo','shuai') True >>> r.get('guo') 'shuai' >>> r['guo']             'shuai' >>> r.keys() ['guo'] >>> r.dbsize()         #当前数据库包含多少条数据       1L >>> r.delete('guo') 1 >>> r.save()               #执行“检查点”操作,将数据写回磁盘。保存时阻塞 True >>> r.get('guo'); >>> r.flushdb()        #清空r中的所有数据 True | 
3. pipeline操作
管道(pipeline)是redis在提供单个请求中缓冲多条服务器命令的基类的子类。它通过减少服务器-客户端之间反复的TCP数据库包,从而大大提高了执行批量命令的功能。
| 1 2 3 4 5 6 7 8 | >>> p = r.pipeline()        --创建一个管道 >>> p.set('hello','redis') >>> p.sadd('faz','baz') >>> p.incr('num') >>> p.execute() [True, 1, 1] >>> r.get('hello') 'redis' | 
管道的命令可以写在一起,如:
| 1 | >>> p.set('hello','redis').sadd('faz','baz').incr('num').execute() | 
默认的情况下,管道里执行的命令可以保证执行的原子性,执行pipe = r.pipeline(transaction=False)可以禁用这一特性。
4. 应用场景 – 页面点击数
《Redis Cookbook》对这个经典场景进行详细描述。假定我们对一系列页面需要记录点击次数。例如论坛的每个帖子都要记录点击次数,而点击次数比回帖的次数的多得多。如果使用关系数据库来存储点击,可能存在大量的行级锁争用。所以,点击数的增加使用redis的INCR命令最好不过了。
当redis服务器启动时,可以从关系数据库读入点击数的初始值(1237这个页面被访问了34634次)
| 1 2 | >>> r.set("visit:1237:totals",34634) True | 
每当有一个页面点击,则使用INCR增加点击数即可。
| 1 2 3 4 | >>> r.incr("visit:1237:totals") 34635 >>> r.incr("visit:1237:totals") 34636 | 
页面载入的时候则可直接获取这个值
| 1 2 | >>> r.get ("visit:1237:totals") '34636' | 
5. 使用hash类型保存多样化对象
当有大量类型文档的对象,文档的内容都不一样时,(即“表”没有固定的列),可以使用hash来表达。
| 1 2 3 4 5 6 7 8 9 10 11 12 | >>> r.hset('users:jdoe',  'name', "John Doe") 1L >>> r.hset('users:jdoe', 'email', 'John@test.com') 1L >>> r.hset('users:jdoe',  'phone', '1555313940') 1L >>> r.hincrby('users:jdoe', 'visits', 1) 1L >>> r.hgetall('users:jdoe') {'phone': '1555313940', 'name': 'John Doe', 'visits': '1', 'email': 'John@test.com'} >>> r.hkeys('users:jdoe') ['name', 'email', 'phone', 'visits'] | 
6. 应用场景 – 社交圈子数据
在社交网站中,每一个圈子(circle)都有自己的用户群。通过圈子可以找到有共同特征(比如某一体育活动、游戏、电影等爱好者)的人。当一个用户加入一个或几个圈子后,系统可以向这个用户推荐圈子中的人。
我们定义这样两个圈子,并加入一些圈子成员。
| 1 2 3 4 5 6 7 8 9 10 11 12 | >>> r.sadd('circle:game:lol','user:debugo') 1 >>> r.sadd('circle:game:lol','user:leo') 1 >>> r.sadd('circle:game:lol','user:Guo') 1 >>> r.sadd('circle:soccer:InterMilan','user:Guo') 1 >>> r.sadd('circle:soccer:InterMilan','user:Levis') 1 >>> r.sadd('circle:soccer:InterMilan','user:leo') 1 | 
#获得某一圈子的成员
| 1 2 3 | >>> r.smembers('circle:game:lol') set(['user:Guo', 'user:debugo', 'user:leo']) redis> smembers circle:jdoe:family     | 
可以使用集合运算来得到几个圈子的共同成员:
| 1 2 3 4 | >>> r.sinter('circle:game:lol', 'circle:soccer:InterMilan') set(['user:Guo', 'user:leo']) >>> r.sunion('circle:game:lol', 'circle:soccer:InterMilan') set(['user:Levis', 'user:Guo', 'user:debugo', 'user:leo']) | 
7. 应用场景 – 实时用户统计
Counting Online Users with Redis介绍了这个方法。当我们需要在页面上显示当前的在线用户时,就可以使用Redis来完成了。首先获得当前时间(以Unix timestamps方式)除以60,可以基于这个值创建一个key。然后添加用户到这个集合中。当超过你设定的最大的超时时间,则将这个集合设为过期;而当需要查询当前在线用户的时候,则将最后N分钟的集合交集在一起即可。由于redis连接对象是线程安全的,所以可以直接使用一个全局变量来表示。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | import time from redis import Redis from datetime import datetime ONLINE_LAST_MINUTES = 5 redis = Redis() def mark_online(user_id):         #将一个用户标记为online     now = int(time.time())        #当前的UNIX时间戳     expires = now + (app.config['ONLINE_LAST_MINUTES'] * 60) + 10    #过期的UNIX时间戳     all_users_key = 'online-users/%d' % (now // 60)        #集合名,包含分钟信息     user_key = 'user-activity/%s' % user_id                     p = redis.pipeline()     p.sadd(all_users_key, user_id)                         #将用户id插入到包含分钟信息的集合中     p.set(user_key, now)                                   #记录用户的标记时间     p.expireat(all_users_key, expires)                     #设定集合的过期时间为UNIX的时间戳     p.expireat(user_key, expires)     p.execute() def get_user_last_activity(user_id):        #获得用户的最后活跃时间     last_active = redis.get('user-activity/%s' % user_id)  #如果获取不到,则返回None     if last_active is None:         return None     return datetime.utcfromtimestamp(int(last_active)) def get_online_users():                     #获得当前online用户的列表     current = int(time.time()) // 60             minutes = xrange(app.config['ONLINE_LAST_MINUTES'])     return redis.sunion(['online-users/%d' % (current - x)        #取ONLINE_LAST_MINUTES分钟对应集合的交集                          for x in minutes | 
使用Python操作Redis应用场景的更多相关文章
- Python操作Redis(一)
		redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set ... 
- python操作redis用法详解
		python操作redis用法详解 转载地址 1.redis连接 redis提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用 ... 
- redis 原生操作 &  python操作redis
		一.基本介绍 1.简介 Redis是由意大利人Salvatore Sanfilippo(网名:antirez)开发的一款内存高速缓存数据库.Redis全称为:Remote Dictionary Ser ... 
- redis缓存数据库及Python操作redis
		缓存数据库介绍 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库,随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站, 特 ... 
- 五、Python操作redis
		五.Python操作redis 一.python对redis基本操作 (1)连接redis # 方式1 import redis r = redis.Redis(host='127.0.0.1', p ... 
- Python—操作redis
		Python操作redis 连接方式:点击 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建, ... 
- python——操作Redis
		在使用django的websocket的时候,发现web请求和其他当前的django进程的内存是不共享的,猜测django的机制可能是每来一个web请求,就开启一个进程去与web进行交互,一次来达到利 ... 
- Python操作Redis、Memcache、RabbitMQ、SQLAlchemy
		Python操作 Redis.Memcache.RabbitMQ.SQLAlchemy redis介绍:redis是一个开源的,先进的KEY-VALUE存储,它通常被称为数据结构服务器,因为键可以包含 ... 
- Python操作redis系列之 列表(list) (四)
		# -*- coding: utf- -*- import redis r =redis.Redis(host=,password="ZBHRwlb1608") 1. Lpush ... 
随机推荐
- nginx配置文件解答
			nginx配置文件详解: server { listen 80; servername www.nginx1.com location / { root ... 
- python多线程--优先级队列(Queue)
			Python的Queue模块中提供了同步的.线程安全的队列类,包括FIFO(先入先出)队列Queue,LIFO(后入先出)队列LifoQueue,和优先级队列PriorityQueue.这些队列都实现 ... 
- [codevs3622] 假期(单调队列)
			传送门 首先考虑暴力做法,可以先求一遍前缀和 sum,然后ans = max(ans, sum[i] - sum[k]) (i - q <= k <= i - p) 但这个肯定会超时. 仔 ... 
- ***apache做301重定向的方法
			将不带www的定向到带www去 方法一:加在httpd.conf 1.这里我使用mod_rewrite重写URL的方式来做,做之前朋友记得检查一下你的apache是否已经加载了rewrite模块.如图 ... 
- Django的form,model自定制
			一.Form组件原理: django框架提供了一个form类,来处理web开发中的表单相关事项.众所周知,form最常做的是对用户输入的内容进行验证,为此django的forms类提供了全面的内容验证 ... 
- 洛谷——P1451 求细胞数量
			P1451 求细胞数量 题目描述 一矩形阵列由数字0到9组成,数字1到9代表细胞,细胞的定义为沿细胞数字上下左右若还是细胞数字则为同一细胞,求给定矩形阵列的细胞个数.(1<=m,n<=10 ... 
- c++ static const
			static 是c++中很常用的修饰符,它被用来控制变量的存储方式和可见性,下面我将从 static 修饰符的产生原因.作用谈起,全面分析static 修饰符的实质. static 的两大作用: 一. ... 
- 你创建线程池最好分为两种线程池,io密集型线程池,或者cpu密集型线程池
			你创建线程池最好分为两种线程池,io密集型线程池,或者cpu密集型线程池. 否则,如果只用一个线程池的话,不管是iO密集的线程,或者cpu消耗大的都放在同一个线程池的话,会发生线程池被撑满的情况 
- linux字符驱动之poll机制按键驱动
			在上一节中,我们讲解了如何自动创建设备节点,实现一个中断方式的按键驱动.虽然中断式的驱动,效率是蛮高的,但是大家有没有发现,应用程序的死循环里的读函数是一直在读的:在实际的应用场所里,有没有那么一种情 ... 
- 选带傅里叶变换(zoom-fft)
			选带傅里叶变换的原理大家能够看书.大致的步骤为 移频 (将选带的中心频率移动到零频) 数字低通滤波器 (防止频率混叠) 又一次採样 (将採样的数据再次间隔採样,间隔的数据取决于分析的带宽,就是放大 ... 
