redis字符串操作
import redis
conn = redis.Redis()
1 set(name, value, ex=None, px=None, nx=False, xx=False)
conn.set('name','lqz')
2 setnx(name, value)
3 psetex(name, time_ms, value)
4 mset(*args, **kwargs)
conn.mset({'name':'xxx', 'age':'xxx'})
4 get(name)
5 mget(keys, *args)
6 getset(name, value)
7 getrange(key, start, end)
8 setrange(name, offset, value)
9 setbit(name, offset, value)
10 getbit(name, offset)
11 bitcount(key, start=None, end=None)
12 strlen(name)
13 incr(self, name, amount=1)
14 incrbyfloat(self, name, amount=1.0)
15 decr(self, name, amount=1)
16 append(key, value)
conn.close()
重点记:get set strlen append
redis Hash操作
1 hset(name, key, value)
conn.hset('user_info', 'age', 22)
2 hmset(name, mapping)
3 hget(name,key)
res=conn.hget('userinfo','age')
4 hmget(name, keys, *args)
res=conn.hmget('userinfo',['name','age'])
5 hgetall(name)
6 hlen(name)
7 hkeys(name)
res=conn.hkeys('userinfo')
8 hvals(name)
9 hexists(name, key)
10 hdel(name,*keys)
11 hincrby(name, key, amount=1)
12 hincrbyfloat(name, key, amount=1.0)
13 hscan(name, cursor=0, match=None, count=None)
14 hscan_iter(name, match=None, count=None)
重点掌握:hset hget hlen hexists hdel
redis列表操作
1 lpush(name,values)
2 lpushx(name,value)
3 rpushx(name, value) 表示从右向左操作
4 llen(name)
5 linsert(name, where, refvalue, value))
6 lset(name, index, value)
7 lrem(name, value, num)
8 lpop(name)
9 lindex(name, index)
10 lrange(name, start, end)
11 ltrim(name, start, end)
12 rpoplpush(src, dst)
13 blpop(keys, timeout)
14 brpoplpush(src, dst, timeout=0)
15 自定义增量迭代
redis管道
问:redis是否支持事务
说支持不支持都可以
redis本身不支持事务,但是可以通过管道,实现部分事务的功能
redis事务机制可以保证一致性和隔离性,无法保证持久性,但是对于redis而言,本身是内存数据库,所以持久化不是必须属性。原子性需要自己进行检查,尽可能保证。
redis 通过管道,来保证命令要么都成功,要么都失败,完成事务的一致性,但是管道只能用在单实例,集群环境中,不支持pipline
import redis
conn = redis.Redis()
pipline = conn.pipeline(transaction=True)
pipline.decr('a', 2)
raise Exception('我崩了')
pipline.incr('b', 2)
pipline.execute()
conn.close()
redis其他操作
import redis
conn = redis.Redis()
conn.close()
django中集成redis
from user.POOL import pool
import redis
def index(request):
conn = redis.Redis(connection_pool=pool)
conn.incr('page_view')
res = conn.get('page_view')
return HttpResponse('被你看了%s次' % res)
1.-下载
2.-配置文件配置
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/0",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
"CONNECTION_POOL_KWARGS": {"max_connections": 100}
}
}
}
3.使用
from django_redis import get_redis_connection
def index(request):
conn = get_redis_connection(alias="default")
conn.incr('page_view')
res = conn.get('page_view')
return HttpResponse('被你看了%s次' % res)
-如果配置文件中配置了 CACHES ,以后django的缓存,数据直接放在redis中
-以后直接使用cache.set 设置值,可以传过期时间
-使用cache.get 获取值
-强大之处在于,可以直接缓存任意的python对象,底层使用pickle实现的
celery介绍
1 完成异步任务:可以提高项目的并发量,之前开启线程做,现在使用celery做
2 完成延迟任务
3 完成定时任务
-消息中间件:broker 提交的任务(函数)都放在这里,celery本身不提供消息中间件,需要借助于第三方:redis,rabbitmq
-任务执行单元:worker,真正执行任务的地方,一个个进程,执行函数
-结果存储:backend,函数return的结果存储在这里,celery本身不提供结果存储,借助于第三方:redis,数据库,rabbitmq
