Redis简介:
'''
redis:
缓存,例如两个个程序A,B之间要进行数据共享,A可以把数据存在redis(内存里),其他程序都可以访问redis里的数据,
这样通过中间商redis就实现了两个程序的内存共享。类似的程序有redis,mongdb,memcache,redis和memcache用的比较多
redis默认存到内存,手动调用后同步到硬盘。 memcache只能存到内存
redis用单线程异步实现的并发
redis就是简单的key-value缓存系统
'''
Python操作Redis包:
首先要安装Redis:pip install redis
import redis # 第一种写法
'''
r = redis.Redis(host='127.0.0.1', port=6379)
r.set('foo', 'BAR')
print(r.get('foo'))
'''
# 第二种写法:连接池。与redis频繁交互的时候就不用不停的建连接
pool = redis.ConnectionPool(host='127.0.0.1', port=6379)
r = redis.Redis(connection_pool=pool)
r.set('foo', 'BAR')
print(r.get('foo'))
redis操作string: 来自http://www.cnblogs.com/alex3714/articles/6217453.html
redis中的String在在内存中按照一个name对应一个value来存储。如图:
set(name, value, ex=None, px=None, nx=False, xx=False)
1 2 3 4 5 6 |
|
setnx(name, value)
1 |
|
setex(name, value, time)
1 |
|
psetex(name, time_ms, value)
1 |
|
mset(*args, **kwargs)
1 2 3 4 5 |
|
get(name)
1 |
|
mget(keys, *args)
1 2 3 4 5 |
|
getset(name, value)
1 |
|
getrange(key, start, end)
1 2 3 4 5 6 |
|
setrange(name, offset, value)
1 2 3 4 |
|
setbit(name, offset, value)
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 |
|
*用途举例,用最省空间的方式,存储在线用户数及分别是哪些用户在线
getbit(name, offset)
1 |
|
bitcount(key, start=None, end=None)
1 2 3 4 5 |
|
strlen(name)
1 |
|
incr(self, name, amount=1)
1 2 3 4 5 6 7 |
|
incrbyfloat(self, name, amount=1.0)
1 2 3 4 5 |
|
decr(self, name, amount=1)
1 2 3 4 5 |
|
append(key, value)
1 2 3 4 5 |
|