Python任务调度模块APScheduler使用


Posted in Python onApril 15, 2020

APScheduler是一个Python定时任务框架,使用起来十分方便。提供了基于日期、固定时间间隔以及crontab类型的任务,并且可以持久化任务、并以daemon方式运行应用。

在APScheduler中有四个组件:

  • 触发器(trigger)包含调度逻辑,每一个作业有它自己的触发器,用于决定接下来哪一个作业会运行。除了他们自己初始配置意外,触发器完全是无状态的。简单说就是应该说明一个任务应该在什么时候执行。
  • 作业存储(job store)存储被调度的作业,默认的作业存储是简单地把作业保存在内存中,其他的作业存储是将作业保存在数据库中。一个作业的数据将在保存在持久化作业存储时被序列化,并在加载时被反序列化。调度器不能分享同一个作业存储。
  • 执行器(executor)处理作业的运行,他们通常通过在作业中提交制定的可调用对象到一个线程或者进城池来进行。当作业完成时,执行器将会通知调度器。
  • 调度器(scheduler)任务控制器:通过配置executor、jobstore、trigger,使用线程池(ThreadPoolExecutor默认值20)或进程池(ProcessPoolExecutor 默认值5)并且默认最多3个(max_instances)任务实例同时运行,实现对job的增删改查等调度控制

你需要选择合适的调度器,这取决于你的应用环境和你使用APScheduler的目的。通常最常用的两个:

BlockingScheduler:当调度器是你应用中唯一要运行的东西时使用。

BackgroundScheduler:当你不运行任何其他框架时使用,并希望调度器在你应用的后台执行。

作业存储

支持4中作业存储,分别是:MemoryJobStore(存储在内存中)、sqlalchemy(关系型数据库)、mongodb(文档数据库)、redis(内存型键值对数据库)

触发方式

date:固定日期触发器:任务只运行一次,运行完毕自动清除;若错过指定运行时间,任务不会被创建

interval:时间间隔触发器,每个一定时间间隔执行一次。

cron:cron风格的任务触发。

Python任务调度模块APScheduler使用

Python任务调度模块APScheduler使用

作业操作

1. 添加作业:上面是通过add_job()来添加作业,另外还有一种方式是通过scheduled_job()修饰器来修饰函数。

@sched.scheduled_job('cron', id='my_job_id', day='last sun')

def some_decorated_task():

print("I am printed at 00:00:00 on the last Sunday of every month!")

2. 移除作业

job = scheduler.add_job(myfunc,'interval', minutes=2)

job.remove()

Same,using an explicit job ID:

scheduler.add_job(myfunc,'interval', minutes=2, id='my_job_id')

scheduler.remove_job('my_job_id')

3. 暂停和恢复作业

暂停作业:

?apscheduler.job.Job.pause()

?apscheduler.schedulers.base.BaseScheduler.pause_job()

恢复作业:

?apscheduler.job.Job.resume()

?apscheduler.schedulers.base.BaseScheduler.resume_job()

4. 获得job列表

获得调度作业的列表,可以使用get_jobs()来完成,它会返回所有的job实例。或者使用print_jobs()来输出所有格式化的作业列表。

5. 修改作业

def some_decorated_task():

print("I am printed at 00:00:00 on the last Sunday of every month!")

6. 关闭调度器

默认情况下调度器会等待所有正在运行的作业完成后,关闭所有的调度器和作业存储。如果你不想等待,可以将wait选项设置为False。

scheduler.shutdown()

scheduler.shutdown(wait=False)

作业运行的控制

add_job的第二个参数是trigger,它管理着作业的调度方式。它可以为date, interval或者cron。对于不同的trigger,对应的参数也相同。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python模块学习 datetime介绍
Aug 27 Python
python+django加载静态网页模板解析
Dec 12 Python
python 3利用Dlib 19.7实现摄像头人脸检测特征点标定
Feb 26 Python
python3+PyQt5泛型委托详解
Apr 24 Python
Python 编码规范(Google Python Style Guide)
May 05 Python
python flask安装和命令详解
Apr 02 Python
Python Pandas分组聚合的实现方法
Jul 02 Python
Python在Matplotlib图中显示中文字体的操作方法
Jul 29 Python
python datetime中strptime用法详解
Aug 29 Python
Python3 main函数使用sys.argv传入多个参数的实现
Dec 25 Python
django rest framework serializers序列化实例
May 13 Python
Python爬虫之Selenium设置元素等待的方法
Dec 04 Python
Python实现代码块儿折叠
Apr 15 #Python
Python类中的装饰器在当前类中的声明与调用详解
Apr 15 #Python
如何提高python 中for循环的效率
Apr 15 #Python
ipython jupyter notebook中显示图像和数学公式实例
Apr 15 #Python
解决 jupyter notebook 回车换两行问题
Apr 15 #Python
Python使用monkey.patch_all()解决协程阻塞问题
Apr 15 #Python
使用python处理题库表格并转化为word形式的实现
Apr 14 #Python
You might like
php 获取可变函数参数的函数
2009/08/26 PHP
php性能优化分析工具XDebug 大型网站调试工具
2011/05/22 PHP
解析在PHP中使用mysqli扩展库对mysql的操作
2013/07/03 PHP
5种PHP创建数组的实例代码分享
2014/01/17 PHP
PHP+Mysql基于事务处理实现转账功能的方法
2015/07/08 PHP
如何在PHP中读写文件
2020/09/07 PHP
JavaScript效率调优经验
2009/06/04 Javascript
JQuery 1.4 中的Ajax问题
2010/01/23 Javascript
基于jQuery架构javascript基础体系
2011/01/01 Javascript
JS实现文字放大效果的方法
2015/03/03 Javascript
javascript实现校验文件上传控件实例
2015/04/20 Javascript
基于JavaScript实现移除(删除)数组中指定元素
2016/01/04 Javascript
JavaScript中iframe实现局部刷新的几种方法汇总
2016/01/06 Javascript
基于jQuery倒计时插件实现团购秒杀效果
2016/05/13 Javascript
jQuery实现点击后高亮背景固定显示的菜单效果【附demo源码下载】
2016/09/21 Javascript
JavaScript构建自己的对象示例
2016/11/29 Javascript
浅谈JS获取元素的N种方法及其动静态讨论
2017/08/25 Javascript
微信小程序之GET请求的实例详解
2017/09/29 Javascript
JQuery属性操作与循环用法示例
2019/05/15 jQuery
vue.js实现简单购物车功能
2020/05/30 Javascript
Vue-cli打包后如何本地查看的操作
2020/09/02 Javascript
原生JavaScript实现轮播图
2021/01/10 Javascript
Python isinstance判断对象类型
2008/09/06 Python
python实现协同过滤推荐算法完整代码示例
2017/12/15 Python
基于python if 判断选择结构的实例详解
2019/05/06 Python
python文字和unicode/ascll相互转换函数及简单加密解密实现代码
2019/08/12 Python
Python之指数与E记法的区别详解
2019/11/21 Python
python pprint模块中print()和pprint()两者的区别
2020/02/10 Python
在django中使用post方法时,需要增加csrftoken的例子
2020/03/13 Python
Python变量格式化输出实现原理解析
2020/08/06 Python
函授毕业生自我鉴定
2013/11/06 职场文书
人事主管的岗位职责
2013/11/16 职场文书
企业标语口号
2014/06/10 职场文书
单位工作证明范文
2014/09/14 职场文书
mysql中如何用命令创建联合唯一索引
2022/04/20 MySQL
python神经网络 使用Keras构建RNN训练
2022/05/04 Python