Djano+apscheduler实现接口自动化平台定时运行

在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’参数,应该是区时设置的不正确,删除即可在这里插入图片描述

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在Django中,如果一个模型表有多个外键,那么在创建序列化器时,需要使用嵌套序列化器来处理这些外键关系。 具体来说,你可以在主要的序列化器中使用`serializers.SerializerMethodField`字段,并定义一个自定义的方法来嵌套序列化每个外键关系。 例如,假设你有一个`Book`模型,它有一个`author`字段和一个`publisher`字段,它们都是外键关系。你可以创建一个名为`BookSerializer`的序列化器,并在其中使用嵌套序列化器来处理这两个外键关系,如下所示: ```python from rest_framework import serializers from .models import Book, Author, Publisher class AuthorSerializer(serializers.ModelSerializer): class Meta: model = Author fields = '__all__' class PublisherSerializer(serializers.ModelSerializer): class Meta: model = Publisher fields = '__all__' class BookSerializer(serializers.ModelSerializer): author = serializers.SerializerMethodField() publisher = serializers.SerializerMethodField() class Meta: model = Book fields = '__all__' def get_author(self, obj): author = obj.author return AuthorSerializer(author).data def get_publisher(self, obj): publisher = obj.publisher return PublisherSerializer(publisher).data ``` 在上面的代码中,`BookSerializer`中的`author`和`publisher`字段都使用了`SerializerMethodField`,并定义了`get_author`和`get_publisher`方法来进行嵌套序列化。 这样,当你使用`BookSerializer`来序列化`Book`对象时,它将自动嵌套序列化`author`和`publisher`对象,并将它们作为嵌套的JSON对象返回给你的API接口。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值