博客
关于我
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建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
查看>>
mysql开启bin-log日志,用于canal同步
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
MySQL异步操作在C++中的应用
查看>>
MySQL引擎讲解
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>
mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
查看>>
mysql性能优化
查看>>
mysql性能优化学习笔记-存储引擎
查看>>
MySQL性能优化必备25条
查看>>
Mysql性能优化(1):SQL的执行过程
查看>>
Mysql性能优化(2):数据库索引
查看>>