0

0

Django Redis 缓存数据未显示在 redis-cli 中的解决方案

碧海醫心

碧海醫心

发布时间:2026-02-09 11:06:49

|

894人浏览过

|

来源于php中文网

原创

Django Redis 缓存数据未显示在 redis-cli 中的解决方案

django 项目通过 docker 集成 redis 后,`redis-cli` 默认连接 db0 为空,而 django 缓存实际写入的是 db1(或其他非默认库),需正确指定数据库编号并确认缓存后端配置。

在 Django + Docker + Redis 的典型部署中,redis-cli 连接后执行 keys * 返回空结果(仅看到 Celery 的 Kombu 绑定键),并不意味着 Redis 没有数据,而是因为 Django 缓存与 Celery 使用了不同的 Redis 数据库编号(db index),且 Django 缓存后端未显式配置导致回退到本地内存缓存。

✅ 核心原因与修复步骤

1. 确认 Django 缓存后端已正确配置

Django 默认的 CACHES 配置使用 LocMemCache(进程内内存缓存),完全不经过 Redis。必须显式配置为 Redis 后端:

# settings.py
CACHES = {
    "default": {
        "BACKEND": "django.core.cache.backends.redis.RedisCache",
        "LOCATION": "redis://redis:6379/1",  # 注意:使用 db1(非默认 db0)
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
        }
    }
}
⚠️ 若 LOCATION 写成 redis://redis:6379/0,则与 Celery 共用 db0 —— 但 Celery 通常只写 _kombu.binding.* 类键,而 Django 缓存键(如 :1:my_key)仍可能被写入,需配合 -n 0 查看;更推荐分离数据库避免冲突,故推荐 /1。

2. 使用 redis-cli -n 连接到正确的数据库

redis-cli 默认连接 db0,而 Django 缓存写入的是 db1(由 LOCATION 中的 /1 指定)。因此需显式指定数据库:

# 进入 Redis 容器并连接 db1
docker exec -it redis redis-cli -n 1

# 在 redis-cli 中查看所有键
127.0.0.1:6379> keys *
1) ":1:my_cached_value"
2) ":1:session:abc123..."

# 获取缓存值(注意前缀 :1: 是 django-redis 自动添加的 db 标识)
127.0.0.1:6379> get ":1:my_cached_value"
"\"cached_data\""

3. 验证缓存是否真正生效

在 Django Shell 中测试缓存读写:

OmniAudio
OmniAudio

OmniAudio 是一款通过 AI 支持将网页、Word 文档、Gmail 内容、文本片段、视频音频文件都转换为音频播客,并生成可在常见 Podcast ap

下载
# python manage.py shell
>>> from django.core.cache import cache
>>> cache.set('test_key', 'hello_redis', timeout=300)
True
>>> cache.get('test_key')
'hello_redis'

随后立即在 redis-cli -n 1 中执行 keys *,应能看到类似 :1:test_key 的键。

4. (可选)统一环境变量管理

为避免硬编码,建议在 .env 中定义 Redis DB 号,并在 settings.py 中读取:

# .env
REDIS_URL=redis://redis:6379/1
# settings.py
import os
CACHES = {
    "default": {
        "BACKEND": "django.core.cache.backends.redis.RedisCache",
        "LOCATION": os.environ.get("REDIS_URL", "redis://redis:6379/1"),
        "OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient"},
    }
}

✅ 总结

  • ❌ 错误认知:“redis-cli 看不到数据 = Redis 没存进去”
  • ✅ 正确排查路径:
    ① 检查 CACHES['default']['BACKEND'] 是否为 RedisCache(非 LocMemCache);
    ② 核对 LOCATION 中的数据库编号(如 /1);
    ③ 使用 redis-cli -n 1 连接对应 DB;
    ④ 通过 Django Shell 验证缓存读写闭环。

完成上述配置后,redis-cli -n 1 keys * 将清晰显示 Django 缓存键,实现可观测、可调试、可运维的 Redis 缓存集成。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python Web 框架 Django 深度开发
Python Web 框架 Django 深度开发

本专题系统讲解 Python Django 框架的核心功能与进阶开发技巧,包括 Django 项目结构、数据库模型与迁移、视图与模板渲染、表单与认证管理、RESTful API 开发、Django 中间件与缓存优化、部署与性能调优。通过实战案例,帮助学习者掌握 使用 Django 快速构建功能全面的 Web 应用与全栈开发能力。

37

2026.02.04

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

225

2023.12.07

location.assign
location.assign

在前端开发中,我们经常需要使用JavaScript来控制页面的跳转和数据的传递。location.assign就是JavaScript中常用的一个跳转方法。通过location.assign,我们可以在当前窗口或者iframe中加载一个新的URL地址,并且可以保存旧页面的历史记录。php中文网为大家带来了location.assign的相关知识、以及相关文章等内容,供大家免费下载使用。

229

2023.06.27

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

264

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

508

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

407

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

445

2024.04.08

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

989

2023.11.02

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

130

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号