在我们web制作过程中进场使用到缓存技术,那么今天python中的一种简单便捷的缓存技术与大家分享;
以下是在省/市/区三级联动的地址查询做的缓存处理
django_rest_framework缓存应用
使用缓存
省市区的数据是经常被用户查询使用的,而且数据基本不变化,所以我们可以将省市区数据进行缓存处理,减少数据库的查询次数。

在Django REST framework中使用缓存,可以通过drf-extensions扩展来实现。

关于扩展使用缓存的文档,可参考链接http://chibisov.github.io/drf-extensions/docs/#caching

安装
pip install drf-extensions
使用方法
1) 直接添加装饰器

可以在使用rest_framework_extensions.cache.decorators中的cache_response装饰器来装饰返回数据的类视图的对象方法,如

class CityView(views.APIView):
@cache_response()
def get(self, request, *args, **kwargs):

cache_response装饰器可以接收两个参数

@cache_response(timeout=60*60, cache=‘default’)
timeout 缓存时间
cache 缓存使用的Django缓存后端(即CACHES配置中的键名称)
如果在使用cache_response装饰器时未指明timeout或者cache参数,则会使用配置文件中的默认配置,可以通过如下方法指明:

DRF扩展

REST_FRAMEWORK_EXTENSIONS = {
# 缓存时间
‘DEFAULT_CACHE_RESPONSE_TIMEOUT’: 60 * 60,
# 缓存存储
‘DEFAULT_USE_CACHE’: ‘default’,
}
DEFAULT_CACHE_RESPONSE_TIMEOUT 缓存有效期,单位秒
DEFAULT_USE_CACHE 缓存的存储方式,与配置文件中的CACHES的键对应。
注意,cache_response装饰器既可以装饰在类视图中的get方法上,也可以装饰在REST framework扩展类提供的list或retrieve方法上。使用cache_response装饰器无需使用method_decorator进行转换。

2)使用drf-extensions提供的扩展类

drf-extensions扩展对于缓存提供了三个扩展类:

ListCacheResponseMixin

用于缓存返回列表数据的视图,与ListModelMixin扩展类配合使用,实际是为list方法添加了cache_response装饰器

RetrieveCacheResponseMixin

用于缓存返回单一数据的视图,与RetrieveModelMixin扩展类配合使用,实际是为retrieve方法添加了cache_response装饰器

CacheResponseMixin

为视图集同时补充List和Retrieve两种缓存,与ListModelMixin和RetrieveModelMixin一起配合使用。

三个扩展类都是在rest_framework_extensions.cache.mixins中。

为省市区视图添加缓存
因为省市区视图使用了视图集,并且视图集中有提供ListModelMixin和RetrieveModelMixin的扩展(由ReadOnlyModelViewSet提供),所以可以直接添加CacheResponseMixin扩展类。

修改返回省市区信息的视图

from rest_framework_extensions.cache.mixins import CacheResponseMixin

class AreasViewSet(CacheResponseMixin, ReadOnlyModelViewSet):
“”"
行政区划信息
“”"
pagination_class = None # 区划信息不分页

def get_queryset(self):
    """
    提供数据集
    """
    if self.action == 'list':
        return Area.objects.filter(parent=None)
    else:
        return Area.objects.all()

def get_serializer_class(self):
    """
    提供序列化器
    """
    if self.action == 'list':
        return AreaSerializer
    else:
        return SubAreaSerializer

缓存数据保存位置与有效期的设置
我们想把缓存数据保存在redis中,且设置有效期,可以通过在配置文件中定义的方式来实现。

在配置文件中增加

缓存配置

REST_FRAMEWORK_EXTENSIONS = {
# 缓存时间
‘DEFAULT_CACHE_RESPONSE_TIMEOUT’: 60 * 60,
# 缓存存储
‘DEFAULT_USE_CACHE’: ‘default’,
}

相关文章: