キャッシュ

ある女性はとても鋭い意識を持っていたがほとんど記憶力がなかった…働くのに十分なことを覚えていて、熱心に働いた。- Lydia Davis

REST Frameworkのキャッシュは、Djangoが提供するキャッシュユーティリティでうまく機能します。


apiviewやビューセットを使ったキャッシュ

Django はクラスベースのビューをデコレーターで使用する method_decorator を提供します。これは cache_pagevary_on_cookievary_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):
    # With cookie: cache requested url for each user for 2 hours
    @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):
    # With auth: cache requested url for each user for 2 hours
    @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):
    # Cache page for the requested url
    @method_decorator(cache_page(60 * 60 * 2))
    def get(self, request, format=None):
        content = {
            "title": "Post title",
            "body": "Post content",
        }
        return Response(content)

注意: cache_page デコレーターは GETHEAD の status 200 のレスポンスのみキャッシュします。