Heim >Datenbank >Redis >Verwendung von Django-Redis von Redis

Verwendung von Django-Redis von Redis

尚
nach vorne
2020-05-20 09:02:502647Durchsuche

Verwendung von Django-Redis von Redis

Benutzerdefinierter Verbindungspool

Diese Methode ist dieselbe wie die normale Py-Dateioperation von Redis, der Code lautet wie folgt

Ansichten. py

  import redis
  from django.shortcuts import render,HttpResponse
  from utils.redis_pool import POOL
   
  def index(request):
      conn = redis.Redis(connection_pool=POOL)
      conn.hset('kkk','age',18)
   
      return HttpResponse('设置成功')
 def order(request):
     conn = redis.Redis(connection_pool=POOL)
     conn.hget('kkk','age')
  
     return HttpResponse('获取成功')

Operation redis durch Komponenten von Drittanbietern

Installation

pip3 install django-redis

Konfiguration:

settings.py

# redis配置
CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
            "CONNECTION_POOL_KWARGS": {"max_connections": 100}
            # "PASSWORD": "密码",
        }
    }
}

Verwenden Sie:

views.py

import redis
from django.shortcuts import render,HttpResponse
from django_redis import get_redis_connection
 
 
def index(request):
    conn = get_redis_connection("default")
    return HttpResponse('设置成功')
def order(request):
    conn = get_redis_connection("default")
    return HttpResponse('获取成功')
from rest_framework.views import APIView
from rest_framework.response import Response
 
from django.core.cache import cache
 
class OrderView(APIView):
    def get(self,request,*args,**kwargs):
        # conn = get_redis_connection('default')
        cache.set('a','b')
        print(cache.get('a'))
        return Response('..')

Vollständiger Site-Cache

Verwenden Sie Middleware nach einer Reihe von Authentifizierungs- und anderen Vorgängen, wenn der Inhalt vorhanden ist Verwenden Sie im Cache FetchFromCacheMiddleware, um den Inhalt abzurufen und an den Benutzer zurückzugeben. Stellen Sie vor der Rückgabe an den Benutzer fest, ob er bereits im Cache vorhanden ist. Wenn er nicht vorhanden ist, speichert UpdateCacheMiddleware den Cache Vollständiges Site-Caching realisieren.

MIDDLEWARE = [
        'django.middleware.cache.UpdateCacheMiddleware',
        # 其他中间件...
        'django.middleware.cache.FetchFromCacheMiddleware',
    ]

Ein Ort oben, der untere

views.py

from django.shortcuts import render,HttpResponse
import time
 
 
def index(request):
    ctime = str(time.time())
    return HttpResponse(ctime)
 
def order(request):
    ctime = str(time.time())
    return HttpResponse(ctime)

ist mit Full-Site-Cache konfiguriert Zeiten (innerhalb eines bestimmten Bereichs), die von den beiden oben genannten Ansichten zurückgegeben werden, sind die Zeit beim Caching

Einzelansicht-Caching

Methode eins: über den Dekorator

from django.views.decorators.cache import cache_page
 
        @cache_page(60 * 15)
        def my_view(request):
            ...

Methode zwei: über URL

from django.views.decorators.cache import cache_page
 
        urlpatterns = [
            url(r'^foo/([0-9]{1,2})/$', cache_page(60 * 15)(my_view)),
        ]

Partielles Seiten-Caching

1. TemplateTag einführen

{% load cache %}

2. Cache verwenden


{% cache 5000 缓存的key %}
       缓存内容
{% endcache %}

Weitere Redis-Kenntnisse finden Sie in der Spalte

Redis-Einführungs-Tutorial.

Das obige ist der detaillierte Inhalt vonVerwendung von Django-Redis von Redis. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:cnblogs.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen