Django项目定期自动清除过期session的2种方法实例
作者:山高路远,看世界,也找自己
如果用户主动退出,session会自动清除,如果没有退出就一直保留,记录数越来越大,要定时清理没用的session,下面这篇文章主要给大家介绍了关于Django项目定期自动清除过期session的2种方法,需要的朋友可以参考下
非自动方法
python manage.py clearsessions
第一种方法通用方法(利用APScheduler定时清除)
安装插件
pip install apscheduler
添加定时任务
找到项目同名的app文件夹中的wsgi.py
修改wsgi.py
添加如下代码在wsgi.py
import os from apscheduler.schedulers.background import BackgroundScheduler scheduler = BackgroundScheduler() # 定时任务, 清空session数据库,这个库不清的话,会不停的增大 #days为int值,几天一清理 #start_date开始日期 @scheduler.scheduled_job(trigger='interval', days=1,start_date='2022-05-02 20:08:00', id='clear_session') def clear_session_job(): print('clear session data base') # 命令行执行python manage.py clearsessions,可以清除已经失效的session os.system('python manage.py clearsessions') scheduler.start()
运行效果
运行前数据库中session:
运行:
clear session data base !!
注意:警告不属于报错!!
运行后数据库中session:
显而易见,所有过期的sessions全部被清理了
完成
以后运行django项目时候每天都会自动在规定时间里面清除过期的sessions
利用宝塔面板(baota)的计划面板(shell脚本)
由于我的项目是利用宝塔搭建在服务器上的,所以我也使用了很多宝塔的自动化脚本进行运行和维护我的服务器
进入shell编辑面
计划任务 -> 任务类型(shell脚本)-> 任务名称(自行命名)-> 执行周期(自行设置)
编写shell脚本
#!/bin/sh #cd manage.py所在的项目文件夹 cd /www/wwwroot/vedio python3 manage.py clearsessions
执行脚本
运行效果
运行前数据库中session:十六条session数据,六条过期session
执行日志:
运行后数据库中session:十条数据,过期的已经被删掉了
完成
以后运行django项目时候每天都会自动在规定时间里面清除过期的sessions
总结
到此这篇关于Django项目定期自动清除过期session的文章就介绍到这了,更多相关Django定期自动清除过期session内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!