zoukankan      html  css  js  c++  java
  • 使用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)
    
  • 相关阅读:
    springboot2.0整合logback日志(详细)
    关于Logstash中grok插件的正则表达式例子
    feign多文件上传
    HBase API(新版本)
    HBase基础知识
    Hive数据操作和数据查询
    Hive数据定义
    Hive基础知识
    Hive安装
    Spark词频统计,求TOP值,文件排序,二次排序
  • 原文地址:https://www.cnblogs.com/chmily/p/12054910.html
Copyright © 2011-2022 走看看