[DRF] Caching

강민성·2024년 9월 26일

DRF API Guide

목록 보기
15/28

캐싱 (Caching)

“한 여자가 있었는데, 그녀는 매우 예리한 의식을 가지고 있었지만 거의 기억력이 없었다... 그녀는 일할 만큼의 기억은 가지고 있었고, 열심히 일했다.”
- 리디아 데이비스 (Lydia Davis)

DRF의 캐싱은 장고(Django)에서 제공하는 캐싱 기능들과 잘 호환됩니다.

apiviewviewsets에서 캐시 사용하기

장고는 클래스 기반 뷰(class based views)에서 데코레이터(decorator)를 사용할 수 있도록 method_decorator를 제공합니다. 이는 cache_page, vary_on_cookie, vary_on_headers와 같은 다른 캐시 데코레이터들과 함께 사용할 수 있습니다.

from django.utils.decorators import method_decorator
from django.views.decorators.cache import cache_page
from django.views.decorators.vary import vary_on_cookie, vary_on_headers

from rest_framework.response import Response
from rest_framework.views import APIView
from rest_framework import viewsets


class UserViewSet(viewsets.ViewSet):
    # 쿠키 기반: 각 사용자에 대해 요청된 URL을 2시간 동안 캐시합니다.
    @method_decorator(cache_page(60 * 60 * 2))
    @method_decorator(vary_on_cookie)
    def list(self, request, format=None):
        content = {
            "user_feed": request.user.get_user_feed(),
        }
        return Response(content)


class ProfileView(APIView):
    # 인증 기반: 각 사용자에 대해 요청된 URL을 2시간 동안 캐시합니다.
    @method_decorator(cache_page(60 * 60 * 2))
    @method_decorator(vary_on_headers("Authorization"))
    def get(self, request, format=None):
        content = {
            "user_feed": request.user.get_user_feed(),
        }
        return Response(content)


class PostView(APIView):
    # 요청된 URL에 대해 페이지를 캐시합니다.
    @method_decorator(cache_page(60 * 60 * 2))
    def get(self, request, format=None):
        content = {
            "title": "Post title",
            "body": "Post content",
        }
        return Response(content)

@api_view 데코레이터와 캐시 사용하기

@api_view 데코레이터를 사용할 때는, 장고에서 제공하는 메서드 기반의 캐시 데코레이터들(cache_page, vary_on_cookie, vary_on_headers)을 직접 호출할 수 있습니다.

from django.views.decorators.cache import cache_page
from django.views.decorators.vary import vary_on_cookie

from rest_framework.decorators import api_view
from rest_framework.response import Response


@cache_page(60 * 15)
@vary_on_cookie
@api_view(["GET"])
def get_user_list(request):
    content = {"user_feed": request.user.get_user_feed()}
    return Response(content)

참고: cache_page 데코레이터는 오직 상태 코드 200을 가진 GETHEAD 응답만을 캐싱합니다.

Reference

DRF API Guide - Caching

profile
Back-end Junior Developer

0개의 댓글