cache

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

如果一个view在Cache-Control中设置了超时时间,则不管全局的chao'sh'si时间

针对视图来使用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()

下游缓存

ISP的缓存 代理服务器的缓存 浏览器的缓存
通过一系列的HTTP头部来控制下游缓存

Vary

说明了哪个头部是在构建缓存时需要的,如果页面是根据用户的语言习惯来变化的,可设置vary on language
默认缓存的key是用完整url带参数的形式来创建的,如果你的页面是根据请求头部中不同信息来判断的可使用vary来指定这些头部

vary_on_headers

@vary_on_headers('User-Agent', 'Cookie')

vary_on_cookie

cache_control

private public
max_age
no_transform must_revalidate stale_while_revalidate
never_cache

中间件的顺序

设置缓存时,UpdateCacheMiddleware 应在列表前部,这样在其他中间件设置了头部后可正确设置,如session添加了cookie、gzip添加了accept-encoding、locale添加了accept-language

同样的,获取缓存时,FetchFromCacheMiddleware 应在列表后部,这样在其他的中间件设置了头部后才可正确取出缓存

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容