上一篇Django 2.1.7 Session基本操作,解决 'WSGIRequest' object has no attribute 'session' 问题讲述了Django 2如何开启session以及session的基本操作,但是session是存储在mysql中,这是性能较低的作法。最好的方式是采用内存数据库进行存储,本章节主要讲解如何使用redis存储session。
使用Redis存储Session
会话还支持文件、纯cookie、Memcached、Redis等方式存储,下面演示使用redis存储。
1)安装包。
代码语言:javascript复制pip3 install django-redis-sessions
2)修改mysite/settings文件,增加如下项:
代码语言:javascript复制SESSION_ENGINE = 'redis_sessions.session'
SESSION_REDIS_HOST = 'localhost'
SESSION_REDIS_PORT = 6379
SESSION_REDIS_DB = 2
SESSION_REDIS_PASSWORD = ''
SESSION_REDIS_PREFIX = 'session'
3)打开assetinfo/views.py文件,修改session_test视图如下:
代码语言:javascript复制def session_test(request):
request.session['h1']='hello'
return HttpResponse('ok')
4)浏览器访问该视图,在redis客户端中查看数据如下。
到redis中查询key为rpxw80y4cn72wmxfpp0hyc2x5xmnek02
的值,如下:
[root@server01 ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> KEYS *
1) "rpxw80y4cn72wmxfpp0hyc2x5xmnek02"
127.0.0.1:6379> get rpxw80y4cn72wmxfpp0hyc2x5xmnek02
"Y2YxYjg0ZDAzNjMwZGZjYzljZmJlNGFlNGY5YjY2MzJiNzZhZWVlZTp7ImgxIjoiaGVsbG8ifQ=="
127.0.0.1:6379>
此时session数据已经自动存储在redis中,查询一下mysql看看有无存储数据,如下:
代码语言:javascript复制mysql> select * from django_session;
Empty set (0.00 sec)
mysql>
数据已经没有存储在mysql了。
复制值,在Base64解码中进行解码查看如下图。
查看redis保存的过期时间,如下:
代码语言:javascript复制[root@server01 ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> KEYS *
1) "rpxw80y4cn72wmxfpp0hyc2x5xmnek02"
127.0.0.1:6379> ttl rpxw80y4cn72wmxfpp0hyc2x5xmnek02
(integer) 1166161
127.0.0.1:6379>
设置session的过期时间
session默认过期时间是两周,那么现在来设置一周来看看。代码如下:
代码语言:javascript复制def session_test(request):
request.session['h1']='hello'
request.session.set_expiry(value=7*24*3600) # 一周的过期时间
return HttpResponse('ok')
使用浏览器访问视图,如下:
而redis存储的值也改变,如下:
代码语言:javascript复制127.0.0.1:6379> ttl rpxw80y4cn72wmxfpp0hyc2x5xmnek02
(integer) 604733
127.0.0.1:6379>
redis存储的就是 7*24*3600 = 604800
秒。