使用 Redis 的 Django 缓存

Django caching with Redis

我在这个博客之后使用 redis 实现了 django 缓存:https://realpython.com/caching-in-django-with-redis/

所以我跟着这个,安装了包, 添加于

CACHES = {
"default": {
    "BACKEND": "redis_cache.RedisCache",
    "LOCATION": "redis://127.0.0.1:8000/",
    "OPTIONS": {
        "CLIENT_CLASS": "django_redis.client.DefaultClient"
    },
    "KEY_PREFIX": "example"
}

}

然后在浏览量中。

from django.conf import settings
from django.core.cache.backends.base import DEFAULT_TIMEOUT
from django.views.decorators.cache import cache_page

CACHE_TTL = getattr(settings, 'CACHE_TTL', DEFAULT_TIMEOUT)

然后为函数添加装饰器

@cache_page(CACHE_TTL)
@login_required_dietitian
def patient_profile(request, id):
    data = {}
    return render(request, 'profile.html', {'data':data})

然后我在 运行 服务器

时收到此错误

redis.exceptions.ConnectionError: Connection closed by server.

我是这种缓存技术的新手,有什么解决这个问题的建议吗?

您的配置在端口 8000 上指定了 Redis,默认情况下,Redis 在端口 6379 上运行。看起来它正在尝试连接您的 Django 应用程序,因此出现连接错误。 Redis 作为一个单独的进程运行,监听端口 6379 上的请求。