摘要:使用擴(kuò)展類使用了視圖集用于緩存返回列表數(shù)據(jù)的視圖,與擴(kuò)展類配合使用,實(shí)際是為方法添加了裝飾器用于緩存返回單一數(shù)據(jù)的視圖,與擴(kuò)展類配合使用,實(shí)際是為方法添加了裝飾器為視圖集同時補(bǔ)充和兩種緩存,與和一起配合使用。
在以往的后臺數(shù)據(jù)訪問時,我們往往都會進(jìn)行數(shù)據(jù)庫查詢,基本的流程是這樣的:
圖中發(fā)生了三次請求,則很正常向數(shù)據(jù)庫查詢了三次。但是現(xiàn)在有這樣一個場景:我們有1000個人在一個十分鐘內(nèi)向一個我們網(wǎng)站都看了同一個文章,那么我們有沒有哪些可以優(yōu)化我們的后端代碼,因?yàn)檫@只是一篇文章在短時間內(nèi)就被訪問了1000次,當(dāng)然我們網(wǎng)站的文章是海量的,那我們該怎么辦?那么我們的數(shù)據(jù)緩存就派上用場了,基本的流程是這樣的:
在第一次請求的時候查看緩存中(redis)是否有數(shù)據(jù),有數(shù)據(jù)則直接返回響應(yīng)
若redis中沒有數(shù)據(jù),則查詢數(shù)據(jù)庫
查詢數(shù)據(jù)庫并將數(shù)據(jù)保存到redis中,返回響應(yīng)
這就是我們?yōu)槭裁粗徊樵兞艘淮螖?shù)據(jù)庫,若有1000次,我們在緩存時間內(nèi)也只需要查詢一次數(shù)據(jù)庫,這里向redis中獲取數(shù)據(jù)也需要耗時,但是由于redis數(shù)據(jù)存儲在內(nèi)存中,數(shù)據(jù)獲取性能較數(shù)據(jù)庫高了不止一點(diǎn)半點(diǎn)。
那么在drf項(xiàng)目中如何去實(shí)現(xiàn)呢?只需要簡單的三步
pip install drf-extensions配置(可以省略)
# DRF擴(kuò)展 REST_FRAMEWORK_EXTENSIONS = { # 緩存時間 "DEFAULT_CACHE_RESPONSE_TIMEOUT": 60 * 60, }使用
使用cache_response裝飾器
from rest_framework.response import Response from rest_framework import views from rest_framework_extensions.cache.decorators import ( cache_response ) from myapp.models import City class CityView(views.APIView): @cache_response() def get(self, request, *args, **kwargs): cities = City.objects.all().values_list("name", flat=True) return Response(cities)
注意,cache_response裝飾器既可以裝飾在類視圖中的get方法上,也可以裝飾在REST framework擴(kuò)展類提供的list或retrieve方法上。使用cache_response裝飾器無需使用method_decorator進(jìn)行轉(zhuǎn)換。
使用擴(kuò)展類(使用了視圖集ViewSet)
ListCacheResponseMixin:用于緩存返回列表數(shù)據(jù)的視圖,與ListModelMixin擴(kuò)展類配合使用,實(shí)際是為list方法添加了cache_response裝飾器
RetrieveCacheResponseMixin:用于緩存返回單一數(shù)據(jù)的視圖,與RetrieveModelMixin擴(kuò)展類配合使用,實(shí)際是為retrieve方法添加了cache_response裝飾器
CacheResponseMixin:為視圖集同時補(bǔ)充List和Retrieve兩種緩存,與ListModelMixin和RetrieveModelMixin一起配合使用。
from myapps.serializers import UserSerializer from rest_framework_extensions.cache.mixins import CacheResponseMixin class UserViewSet(CacheResponseMixin, viewsets.ModelViewSet):#繼承順序一定在ViewSet前,其實(shí)必須在對應(yīng)的mixin前 serializer_class = UserSerializer
def-extensions官方文檔:http://chibisov.github.io/drf...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/43197.html
摘要:使用擴(kuò)展類使用了視圖集用于緩存返回列表數(shù)據(jù)的視圖,與擴(kuò)展類配合使用,實(shí)際是為方法添加了裝飾器用于緩存返回單一數(shù)據(jù)的視圖,與擴(kuò)展類配合使用,實(shí)際是為方法添加了裝飾器為視圖集同時補(bǔ)充和兩種緩存,與和一起配合使用。 在以往的后臺數(shù)據(jù)訪問時,我們往往都會進(jìn)行數(shù)據(jù)庫查詢,基本的流程是這樣的: showImg(https://segmentfault.com/img/bVbooYc?w=784&h...
摘要:使用擴(kuò)展類使用了視圖集用于緩存返回列表數(shù)據(jù)的視圖,與擴(kuò)展類配合使用,實(shí)際是為方法添加了裝飾器用于緩存返回單一數(shù)據(jù)的視圖,與擴(kuò)展類配合使用,實(shí)際是為方法添加了裝飾器為視圖集同時補(bǔ)充和兩種緩存,與和一起配合使用。 在以往的后臺數(shù)據(jù)訪問時,我們往往都會進(jìn)行數(shù)據(jù)庫查詢,基本的流程是這樣的: showImg(https://segmentfault.com/img/bVbooYc?w=784&h...
摘要:自帶了一個健壯的緩存系統(tǒng)來保存動態(tài)頁面,避免每次請求都重新計(jì)算。緩存中的和方法是很常見的。盡量放在第一個繼承的類設(shè)置過期時間根據(jù)自己需求加緩存。目前這個緩存使用的是內(nèi)存。 概述:對于中等流量的網(wǎng)站來說,盡可能的減少開銷是非常必要的。緩存數(shù)據(jù)就是為了保存那些需要很多計(jì)算資源的結(jié)果,這樣的話就不必在下次重復(fù)消耗計(jì)算資源。獲取數(shù)據(jù)的數(shù)據(jù)的時候就是去緩存中拿,拿到了直接返回,沒拿到就去數(shù)據(jù)庫中...
摘要:后端實(shí)現(xiàn)跨域第三方擴(kuò)展在介紹之前,我先介紹兩個概念同源策略跨域同源策略同源策略是一種約定,是瀏覽器的一種安全機(jī)制。這里同源需要協(xié)議域名端口三者都相同,否則不能進(jìn)行訪問。跨域不同源之間的網(wǎng)站通信就是跨域。 在使用django-rest-framework開發(fā)項(xiàng)目的時候我們總是避免不了跨域的問題,因?yàn)楝F(xiàn)在大多數(shù)的項(xiàng)目都是前后端分離,前后端項(xiàng)目部署在不同的web服務(wù)器上,因?yàn)槲覀兪呛蠖顺绦騿T...
閱讀 2830·2021-11-22 15:11
閱讀 3550·2021-09-28 09:43
閱讀 2896·2019-08-30 13:05
閱讀 3438·2019-08-30 11:18
閱讀 1454·2019-08-29 16:34
閱讀 1311·2019-08-29 13:53
閱讀 2916·2019-08-29 11:03
閱讀 1668·2019-08-29 10:57