# redis-simple-cache
redis-simple-cache is a pythonic interface for creating a cache over redis.
It provides simple decorators that can be added to any function to cache its return values.
Requirements:
-------------
redis 2.6.2
redis-py 2.7.1 (see requirements.txt file)
Installation:
-------------
pip install redis-simple-cache
or to get the latest version
git clone git://github.com/vivekn/redis-simple-cache.git
cd redis-simple-cache
python setup.py install
Usage:
------
from redis_cache import cache_it_json
@cache_it_json(limit=1000, expire=60 * 60 * 24)
def fib(n):
if n == 0:
return 0
elif n == 1:
return 1
else:
return fib(n-1) + fib(n-2)
`limit` is the maximum number of keys, `expire` is the expire time in seconds.
It is always recommended to specify a expire time, since by default redis-server will only remove keys with an expire time set in a event of full memory. But if you wish your keys to never expire, set `expire` to `None`.
**Note that function arguments and result must be pickleable, since cache_it uses the pickle module.**
It is also possible to use redis-simple-cache as a object-oriented cache:
>> from redis_cache import SimpleCache
>> c = SimpleCache(10) # cache that has a maximum limit of 10 keys
>> c.store("foo", "bar")
>> c.get("foo")
'bar'
>> "foo" in c # efficient membership test, time-complexity O(1)
True
>> len(c) # efficient cardinality calculation, time-complexity O(1)
1
>> c.keys() # returns all keys, time-complexity O(N) with N being the cache c cardinality
set(['foo'])
>> c.flush() # flushes the cache, time-complexity O(N) with N being the cache c cardinality
>> "foo" in c
False
>> len(c)
0
Check out more examples in the test_rediscache.py file.
Advanced:
---------
Advanced users can customize the decorators even more by passing a SimpleCache object. For example:
my_cache = SimpleCache(limit=100, expire=60 * 60, hashkeys=True, host='localhost', port=6379, db=1, namespace='Fibonacci')
@cache_it(cache=my_cache)
def fib(n):
# ...
`hashkeys` parameter makes the SimpleCache to store keys in md5 hash. It is `True` by default in decorators, but `False` by default in a new SimpleCache object.
`host`, `port` and `db` are the same redis config params used in StrictRedis class of redis-py.
By default, the `namespace` is the name of the module from which the decorated function is called, but it can be overridden with the `namespace` parameter.
AUTHOR: Vivek Narayanan
CONTRIBUTORS:
Flávio Juvenal
Sam Zaydel
David Ng
DJ Gilcrease
Johannes Maximilian Toball
Robert Marshall
Ben Hayden
LICENSE: BSD
徐浪老师
- 粉丝: 8543
- 资源: 1万+
最新资源
- springboot layui 装修验收管理系统(源码+sql)-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip
- 洞见研报中国现制茶饮行业洞察报告- 茶韵新篇:现制茶饮行业的繁荣与前景
- 同步磁阻电机SynRM无传感器高频注入HFI驱动matlab离散模型,使用方波注入,用于低速运行,仿真中使用的是50RPM 用于学习研究
- springboot+vue+redis前后端分离 爱家商城项目(源码+sql)-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip
- CH341SER-ANDROID.zip
- springboot高校跳蚤市场平台(源码+论文报告)-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip
- 【龙艺集团,洞见研报】面对降本增效的挑战,企业与员工如何找到人力管理的平衡点?(降本增效、制造业转型、人力降本)
- springboot美食生活分享平台(源码+论文报告)-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip
- 基于滑膜控制的主动前轮转向(AFS),以横摆角速度偏差为输入(也可以添加质心侧偏角) ,附加转角为输出 模型包括整车七自由度模型、AFS控制器 可以有效改善车辆稳定性
- springboot网上宠物用品商城系统(源码+sql+论文报告)-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip
- 洞见研报周报时讯11.18-11.22
- springboot社区团购管理系统的设计与实现_975sz--论文-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip
- 洞见研报周报时讯11.25-11.29
- hedrive-dir.7z
- springboot网上酒类商城系统(源码+论文报告)-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip
- 洞见研报周报时讯12.2-12.6
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈