博客
关于我
Django的session使用redis数据库作为缓存,控制台报错500,无具体错误提示
阅读量:671 次
发布时间:2019-03-15

本文共 1082 字,大约阅读时间需要 3 分钟。

一、redis作为Django session的缓存数据库设置步骤

(1)安装django-redis-sessions

pip install django-redis-sesisons

(2)修改settings.py

# session使用redis作为缓存,而不是内存SESSION_ENGINE = 'redis_sessions.session'SESSION_REDIS_HOST = "127.0.0.1"SESSION_REDIS_PORT = 6379SESSION_REDIS_DB = 0SESSION_REDIS_PASSWORD = 'face2020'SESSION_REDIS_PREFIX = 'session'

(3)url配置

from django.urls import path, re_pathfrom app1 import viewsurlpatterns = [     re_path(r'setSession/$', views.setSession),    re_path(r'getSession/$', views.getSession),]

(4)视图函数

def setSession(request):        # 存储session    request.session['name'] = name    request.session.set_expiry(300)    return HttpResponse('success')def getSession(request):    name = request.session['name']    return HttpResponse(name)

(5)redis查看

 

 (6)浏览器输入url报错

http://127.0.0.1:8000/setSession/控制台报错如下[10/Apr/2020 19:31:50] "GET/setSession/ HTTP/1.1" 500 145

二、解决方案

(1)修改安装的django-redis-sessions版本,不指定默认安装最新版本。当发现出现错误且不提示错误时说明是包内部错误,需要尝试更换包版本

pip install django-redis-sessions==0.5.6# 可查看包的所有版本pip install django-redis-sessions==#可进行包的卸载pip uninstall django-redis-sessions

 

转载地址:http://vnglz.baihongyu.com/

你可能感兴趣的文章
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>