博客
关于我
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的 DDL和DML和DQL的基本语法
查看>>
mysql的 if else , case when then, IFNULL
查看>>
MySQL的10种常用数据类型
查看>>
MySQL的btree索引和hash索引的区别
查看>>
mysql的cast函数
查看>>
MySql的CRUD(增、删、改、查)操作
查看>>
MySQL的DATE_FORMAT()函数将Date转为字符串
查看>>
MySql的Delete、Truncate、Drop分析
查看>>
MySQL的Geometry数据处理之WKB方案
查看>>
MySQL的Geometry数据处理之WKT方案
查看>>
mysql的grant用法
查看>>
Mysql的InnoDB引擎的表锁与行锁
查看>>
mysql的InnoDB引擎索引为什么使用B+Tree
查看>>
MySQL的InnoDB默认隔离级别为 Repeatable read(可重复读)为啥能解决幻读问题?
查看>>
MySQL的insert-on-duplicate语句详解
查看>>
mysql的logrotate脚本
查看>>
MySQL的my.cnf文件(解决5.7.18下没有my-default.cnf)
查看>>
MySQL的on duplicate key update 的使用
查看>>
MySQL的Replace用法详解
查看>>
mysql的root用户无法建库的问题
查看>>