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的好處是可以在多個服務(wù)器之間共享,集群。
使用方式:
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',
}
}
本地內(nèi)存緩存
這是默認(rèn)的緩存方式,每進程,線程安全
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
'LOCATION': 'unique-snowflake',
}
}
每一個進程是有它自己的cache系統(tǒng),所以會有冗余。
dummy_cache
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.dummy.DummyCache',
}
}
參數(shù)
timeout
默認(rèn)的timeout是300s,可以設(shè)置為None永不過期,設(shè)置為0則關(guān)閉了緩存。
options
不同的緩存系統(tǒng)則不一樣
對應(yīng)locmem、filesystem、database:
MAX_ENTRIES 保存的最多的cache項數(shù)量 默認(rèn)是300 然后會滾動刪除
CULL_FREQUENCY 刪除時的比率的反比
KEY_PREFIX
cache key的開頭部分
VERSION
cache key的版本號
KEY_FUNCTION
一個函數(shù)的位置,該函數(shù)用于把prefix version key組合為最終的key
整個網(wǎng)站使用cache
'django.middleware.cache.UpdateCacheMiddleware'
'django.middleware.cache.FetchFromCacheMiddleware'
設(shè)置
CACHE_MIDDLEWARE_ALIAS,
CACHE_MIDDLEWARE_SECONDS 對應(yīng)會在Expires和Cache-Control中體現(xiàn)
CACHE_MIDDLEWARE_KEY_PREFIX
如果一個view在Cache-Control中設(shè)置了超時時間,則不管全局的chao'sh'si時間
針對視圖來使用cache
cache_page
from django.views.decorators.cache import cache_page
@cache_page(60 * 15)
def my_view(request):
...
可通過參數(shù)設(shè)置timeout,可通過cache參數(shù)來設(shè)置使用cache系統(tǒng),默認(rèn)為default,可設(shè)置key_prefix。
@cache_page(60 * 15, cache="special_cache")
def my_view(request):
...
同時也可在url中包裹來設(shè)置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的緩存 代理服務(wù)器的緩存 瀏覽器的緩存
通過一系列的HTTP頭部來控制下游緩存
Vary
說明了哪個頭部是在構(gòu)建緩存時需要的,如果頁面是根據(jù)用戶的語言習(xí)慣來變化的,可設(shè)置vary on language
默認(rèn)緩存的key是用完整url帶參數(shù)的形式來創(chuàng)建的,如果你的頁面是根據(jù)請求頭部中不同信息來判斷的可使用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
中間件的順序
設(shè)置緩存時,UpdateCacheMiddleware 應(yīng)在列表前部,這樣在其他中間件設(shè)置了頭部后可正確設(shè)置,如session添加了cookie、gzip添加了accept-encoding、locale添加了accept-language
同樣的,獲取緩存時,F(xiàn)etchFromCacheMiddleware 應(yīng)在列表后部,這樣在其他的中間件設(shè)置了頭部后才可正確取出緩存