目录
回到顶部
一, 缓存
由于 Django 是动态网站, 所有每次请求均会去数据进行相应的操作, 当程序访问量大时, 耗时必然会更加明显, 最简单解决方式是使用: 缓存, 缓存将一个某个 views 的返回值保存至内存或者 memcache 中, 5 分钟内再有人来访问时, 则不再去执行 view 中的操作, 而是直接从内存或者 memcache 中之前缓存的内容拿到, 并返回.
Django 中提供了 6 种缓存方式:
开发调试
内存
文件
数据库
Memcache 缓存 (python-Memcached 模块)
Memcache 缓存 (pylibmc 模块)
1, 配置
a, 开发调试
- # 此为开始调试用, 实际内部不做任何操作
- # 配置:
- CACHES = {
- 'default': {
- 'BACKEND': 'django.core.cache.backends.dummy.DummyCache', # 引擎
- 'TIMEOUT': 300, # 缓存超时时间 (默认 300,None 表示永不过期, 0 表示立即过期)
- 'OPTIONS':{
- 'MAX_ENTRIES': 300, # 最大缓存个数 (默认 300)
- 'CULL_FREQUENCY': 3, # 缓存到达最大个数之后, 剔除缓存个数的比例, 即: 1/CULL_FREQUENCY(默认 3)
- },
- 'KEY_PREFIX': '', # 缓存 key 的前缀 (默认空)
- 'VERSION': 1, # 缓存 key 的版本 (默认 1)
'KEY_FUNCTION' 函数名 # 生成 key 的函数 (默认函数会生成为:[前缀: 版本: key] )
- }
- }
- # 自定义 key
- def default_key_func(key, key_prefix, version):
- """
- Default function to generate keys.
- Constructs the key used by all other methods. By default it prepends
- the `key_prefix'. KEY_FUNCTION can be used to specify an alternate
- function with custom key making behavior.
- """ return'%s:%s:%s' % (key_prefix, version, key)
- def get_key_func(key_func):
- """
- Function to decide which key function to use.
- Defaults to ``default_key_func``.
- """
- if key_func is not None:
- if callable(key_func):
- return key_func
- else:
- return import_string(key_func)
- return default_key_func
- View Code
b, 内存
- # 此缓存将内容保存至内存的变量中
- # 配置:
- CACHES = {
- 'default': {
- 'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
- 'LOCATION': 'unique-snowflake',
- }
- }
- # 注: 其他配置同开发调试版本
- View Code
c, 文件
- # 此缓存将内容保存至文件
- # 配置:
- CACHES = {
- 'default': {
- 'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
- 'LOCATION': '/var/tmp/django_cache',
- }
- }
- # 注: 其他配置同开发调试版本
- View Code
d, 数据库
来源: http://www.bubuko.com/infodetail-3201585.html