在Django项目中使用apscheduler实现定时任务
在django中可以直接使用apscheduler库配置定时程序,但因为apscheduler库在运行定时工作(job)时,是将job加载到内存中,当django项目重启时,任务工作也会同步清空(若想将工作计划持久化,需要自己封装到数据库中),所以在此使用的库是
django_apscheduler
1.安装模块
pip install django_apscheduler
pip install apscheduler
(注:在安装完模块后需要使用 python manage.py migrate命令进行迁移数据库,在迁移完成后,会生成 django_apscheduler_djangojob与django_apscheduler_djangojobexecution俩个库)
其中django_apscheduler_djangojob存放的是当前数据库中剩余的工作(job)计划
next_run_time是此工作预计下次运行的时间;
django_apscheduler_djangojobexecution是存放已经运行过或者正在运行工作的历史记录
2.使用模块-初始化
setting中需要将模块加入apps
在django中使用apscheduler库,需要将初始化工作写在 url中,或者view文件中,要能在django服务一运行时,就能加载代码,
所以此处我将代码写在了某APP下的views中
# 导入模块
from apscheduler.schedulers.background import BackgroundScheduler
from django_apscheduler.jobstores import DjangoJobStore, register_events, register_job
from django_apscheduler.models import DjangoJob
#初始化模块
#将已经过时的工作都删除 __lt小于
DjangoJob.objects.filter(next_run_time__lt=datetime.now()).delete() # 将数据库中已经过时的工作删除
# 初始化定时器:BackgroundScheduler为在后台运行
scheduler = BackgroundScheduler()
scheduler.add_jobstore(DjangoJobStore(), 'default')
register_events(scheduler)
scheduler.start() # 此处直接在django服务运行加载时,直接启动定时任务,之后在代码中动态的加入工作计划(job)
3. django代码中动态构建任务
此处是在views视图中加入了一个get方法,以供从前端拿到用户输入的数据,进行构建定时任务
主要构建代码是scheduler.add_job(run, 'cron', hour=hour,minute=minute,id=str(task.id),args=[Case_id, case.name,steps ])
采取的方式是cron和date格式, 当用户输入的具体的时间格式后,会想定时任务中加入一个run方法;
run方法的主要作用就是运行某测试用例。执行测试用例中的测试报告(run方法的具体代码中此不做叙述)
传参使用args=[ ] 的格式传输;
id使用的是自定义任务库的id,当用户想修改一个定时任务时,需要在django_apscheduler_djangojob库中删除这个任务,再重新使用add_job方法构建进入,以达到修改定时任务的效果;
好了,以上就是django使用apscheduler定时任务实现接口自动化定时的全部内容了,
总结:
实现代码全部写在的views中,在顶部导入模块,完成对应初始化工作后,在具体的views视图中,根据用户输入的值,使用add_job方法完成定时任务的构建;
其他—目前遇到的报错:
1.Job identifier (test_jobs) conflicts with an existing job
此错误是因为工作id和数据库中现存在工作id一致导致的,需要修改id名称为别的即可;
2:django.db.utils.OperationalError: database is locked
初步估计是因为开启的job过多,导致连接池不够,改了一种实例化调度器的方式后,可以解决,并且加一个misfire_grace_time属性值将这个值设置大一下,增加容错机制
3:
当使用cron 和data方法进行定时不能运行问题:
因为在创建调度器实例化时,加入了timezone='MST’参数,应该是区时设置的不正确,删除即可