memcached
有两种python库可供使用(python-memcached pylibmc):
django.core.cache.backends.memcached.MemcachedCache
django.core.cache.backends.memcached.PyLibMCCache
在location中可以指定:
ip:port
unix:path
'LOCATION': '127.0.0.1:11211',
'LOCATION': 'unix:/tmp/memcached.sock', #适用于python-memcached
'LOCATION': '/tmp/memcached.sock' # 适用于pylibmc
使用memcached的好处是可以在多个服务器之间共享,集群。
使用方式:
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': [
'172.19.26.240:11211',
'172.19.26.242:11211',
]
}
file cache
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
'LOCATION': '/var/tmp/django_cache',
}
}
内存缓存
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
'LOCATION': 'unique-snowflake',
}
}
每一个进程是有它自己的cache系统,所以会有冗余。
dummy_cache
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.dummy.DummyCache',
}
}
参数
timeout
默认的timeout是300s,可以设置为None永不过期,设置为0则关闭了缓存。
options
不同的缓存系统则不一样
对应locmem、filesystem、database:
MAX_ENTRIES 保存的最多的cache项数量 默认是300 然后会滚动删除
CULL_FREQUENCY 定期删除的频率
KEY_PREFIX
cache key的开头部分
VERSION
cache key的版本号
KEY_FUNCTION
一个函数的位置,该函数用于把prefix version key组合为最终的key
整个网站使用cache
'django.middleware.cache.UpdateCacheMiddleware'
'django.middleware.cache.FetchFromCacheMiddleware'
设置
CACHE_MIDDLEWARE_ALIAS,
CACHE_MIDDLEWARE_SECONDS 对应会在Expires和Cache-Control中体现
CACHE_MIDDLEWARE_KEY_PREFIX
针对视图来使用cache
cache_page
from django.views.decorators.cache import cache_page
@cache_page(60 * 15)
def my_view(request):
...
可通过参数设置timeout,可通过cache参数来设置使用cache系统,默认为default,可设置key_prefix。
@cache_page(60 * 15, cache="special_cache")
def my_view(request):
...
同时也可在url中包裹来设置cache
url(r’^foo/$’, cache_page(60*15)(my_view))
更低层次的使用cache
>>> from django.core.cache import caches
>>> cache1 = caches['myalias']
>>> cache2 = caches['myalias']
>>> cache1 is cache2
True
>>> from django.core.cache import cache
caches['default']
使用
cache.set('my_key', 'hello, world!', 30)
cache.get('my_key')
cache.add('add_key', 'New value') # setdefault
cache.get_or_set('my_new_key', 'my new value', 100)
cache.set_many({'a': 1, 'b': 2, 'c': 3})
cache.get_many(['a', 'b', 'c'])
cache.delete('a')
cache.delete_many(['a', 'b', 'c'])
cache.clear()
cache.incr('num')
cache.decr('num')
cache.close()
Vary
vary_on_headers
@vary_on_headers(‘User-Agent’, ‘Cookie’)
vary_on_cookie
cache_control
private max_age no_transform must_revalidate stale_while_revalidate