博客
关于我
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查询总成绩的前3名学生信息
查看>>
mysql查询慢排查
查看>>
MySQL查询报错ERROR:No query specified
查看>>
mysql查询数据库储存数据的占用容量大小
查看>>
MySQL查询数据库所有表名及其注释
查看>>
MySQL查询数据表中数据记录(包括多表查询)
查看>>
MySQL查询结果排序
查看>>
MYSQL查询语句优化
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>