Django缓存装饰器+失效函数
项目描述
django-cache-utils2提供缓存装饰器和失效函数。
安装
pip install django-cache-utils2
使用
from cache_utils2 import cached, invalidate
@cached(60)
def foo(x, y=0):
print 'foo is called'
return x+y
foo(1, 2) # foo is called
foo(1, y=2)
foo(5, 6) # foo is called
foo(5, 6)
invalidate(foo, {'x': 1, 'y': 2})
foo(1, 2) # foo is called
foo(5, 6)
foo(x=2) # foo is called
foo(x=2)
class Foo(object):
@cached(60)
def foo(self, x, y):
print "foo is called"
return x+y
obj = Foo()
obj.foo(1,2) # foo is called
obj.foo(1,2)
invalidate(Foo.foo, {'x': 1, 'y': 2})
obj.foo(1,2) # foo is called
Django示例
from django.db import models
from cache_utils2 import cached, invalidate
class CityManager(models.Manager):
# cache a method result. 'self' parameter is ignored
@cached(60*60*24)
def default(self):
return self.active()[0]
# cache a method result. 'self' parameter is ignored, args and
# kwargs are used to construct the cache key
@cached(60*60*24)
def get(self, *args, **kwargs):
return super(CityManager, self).get(*args, **kwargs)
class City(models.Model):
# ... field declarations
objects = CityManager()
# cache django model instance method result by instance pk
@cached(30, vary='self.pk')
def has_offers(self):
return self.offer_set.count() > 0
# invalidation of model methods
invalidate(City.has_offers, {'self.pk': 1}
注意
如果装饰函数返回cache_utils2.NO_CACHE,缓存将绕过。
运行测试
获取源代码并运行runtests.py。
项目详情
关闭
django-cache-utils2-0.1.tar.gz的哈希
| 算法 | 哈希摘要 | |
|---|---|---|
| SHA256 | 8b6efe29f7b7428aec54460e07fde214f6ac12f852e766e53dd6723a68600e8c |
|
| MD5 | 55618448c0fbab7d1a356dcb3a947cf2 |
|
| BLAKE2b-256 | 1fb74c30b4da63883504f7cce16d293426b83a0c010ef3c9592fd63a310574ca |