• 使用redis建立缓存数据库存储数据


    接口缓存----把数据放在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)
    
  • 相关阅读:
    LDAP入门
    Java程序员书籍推荐
    docker registry镜像容器时区时间同步
    微服务架构与实践及云原生等相关概念
    ts基础
    内网穿透连接内网下的"我的世界"服务端
    [量子互联] 内网穿透远程连接Linux的SSH
    树莓派开启SSH的N种方法
    [量子互联] 群晖NAS的远程映射配置
    [量子互联] 群晖NAS的qBittorrent端口映射
  • 原文地址:https://www.cnblogs.com/chmily/p/12054910.html
Copyright © 2020-2023  润新知