DRF中使用缓存drf-extensions --- 针对经常查询, 但是不经常变动的数据进行缓存处理的方法

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

在开发某些网站的时候,比如有些不经常或者长时间不会变更的数据,但是,用户会经常查询的数据,为了避免多次查询数据库给数据库带来太大的压力,我们可以及将这些经常被查询的数据,在被查询一次之后,可以在存放在redis缓存中,下次再进行查询的时候,可以直接从redis进行获取,而不需要再查询存储数据的(例如mysql)数据库了;

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

安装

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参数,则会使用配置文件中的默认配置,可以通过在settings.py中进行全局方法配置:

# DRF扩展
REST_FRAMEWORK_EXTENSIONS = {
    # 缓存时间
    'DEFAULT_CACHE_RESPONSE_TIMEOUT': 60 * 60,
    # 缓存存储
    'DEFAULT_USE_CACHE': 'default',
}

其中的default就是下图中的缓存配置中的‘default’
在这里插入图片描述

注意,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中。

这个扩展类在使用的时候,只要需要进行缓存处理的视图函数在继承的时候,继承相关的扩展类,在全部的settings中进行缓存有效期和缓存使用的后端即可:

class CityView(CacheResponseMixin, ReadOnlyModelViewSet):
	。。。。。
# DRF扩展
REST_FRAMEWORK_EXTENSIONS = {
    # 缓存时间
    'DEFAULT_CACHE_RESPONSE_TIMEOUT': 60 * 60,
    # 缓存存储
    'DEFAULT_USE_CACHE': 'default',
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于使用DRF(Django Rest Framework)和Vue的数据导入和导出,可以按照以下步骤进行操作: 1. 在Django创建一个可以导出数据的API视图。你可以使用DRF的`APIView`类作为基类,并在`get`方法编写逻辑来导出数据。例如,你可以使用`HttpResponse`返回CSV格式的数据。 ```python from django.http import HttpResponse from rest_framework.views import APIView class ExportDataAPIView(APIView): def get(self, request, format=None): # 导出数据的逻辑 # 数据可以从数据库或其他来源获取 # 创建CSV数据 csv_data = "col1,col2,col3\nvalue1,value2,value3\n" response = HttpResponse(content_type='text/csv') response['Content-Disposition'] = 'attachment; filename="data.csv"' response.write(csv_data) return response ``` 2. 在Vue创建一个导出数据的页面或组件。你可以使用`axios`库发送GET请求到Django的API视图,并将响应保存为CSV文件并进行下载。 ```javascript import axios from 'axios'; const exportData = () => { axios.get('/api/export-data/', { responseType: 'blob' }) .then(response => { const url = window.URL.createObjectURL(new Blob([response.data])); const link = document.createElement('a'); link.href = url; link.setAttribute('download', 'data.csv'); document.body.appendChild(link); link.click(); }) .catch(error => { console.error(error); }); }; exportData(); ``` 3. 对于数据的导入,你可以在Django创建一个可以接收上传文件的API视图。你可以使用DRF的`APIView`类,并在`post`方法编写逻辑来处理上传的文件。 ```python from rest_framework.parsers import MultiPartParser from rest_framework.views import APIView class ImportDataAPIView(APIView): parser_classes = [MultiPartParser] def post(self, request, format=None): file = request.FILES['file'] # 处理上传文件的逻辑

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值