接口缓存----把数据放在redis数据库中,减少访问量

针对访问量大,且数据较固定的接口,建议建立接口缓存,建立了缓存之后,提取数据就不再走数据库,直接从缓存中提取。同时也减少了数据库压力

比如轮播图接口,每刷新一下首页就会访问一下轮播图接口拿去数据,这时建立接口缓存来处理就可以减轻数据库压力

视图模块:home/views.py

from rest_framework.generics import ListAPIView
from . import models
from . import serializers
from django.conf import settings
from django.core.cache import cache
from rest_framework.response import Response
class BannerListAPIView(ListAPIView):
    queryset = models.Banner.objects.filter(is_delete=False, is_show=True).order_by('-order')[:settings.BANNER_COUNT]
    serializer_class = serializers.BannerModelSerializer
    #访问量大且数据一段时间内较为固定的接口,可以建立接口缓存
    #1、数据从缓存中拿,有直接返回,没有就查询数据库
    #2、查询数据库的数据返回给前台,同时将数据建立缓存
    def get(self, request, *args, **kwargs):  # 群查
        banner_list = cache.get('banner_list') #缓存有,走缓存,没有就走数据库
        if not banner_list:
            # 走数据库拿数据
            response = self.list(request, *args, *kwargs)
            # 保存数据到缓存
            # response.data不是json数据,是drf中自定义的ReturnList类
            cache.set('banner_list', response.data)  # 缓存不设置过期时间,更新任务交给celery异步任务框架
            return response
        return Response(banner_list)