层基本概念
APScheduler四大组件:
-
触发器 triggers :用于设定触发任务的条件
-
任务储存器 job stores:用于存放任务,把任务存放在内存或数据库中
-
执行器 executors: 用于执行任务,可以设定执行模式为单线程或线程池
-
调度器 schedulers: 把上方三个组件作为参数,通过创建调度器实例来运行
触发器
每一个任务都有自己的触发器,触发器用于决定任务下次运行的时间。
任务储存器
默认情况下,任务存放在内存中。也可以配置存放在不同类型的数据库中。如果任务存放在数据库中,那么任务的存取有一个序列化和反序列化的过程,同时修改和搜索任务的功能也是由任务储存器实现。
注!一个任务储存器不要共享给多个调度器,否则会导致状态混乱
执行器
任务会被执行器放入线程池或进程池去执行,执行完毕后,执行器会通知调度器。
调度器
一个调度器由上方三个组件构成,一般来说,一个程序只要有一个调度器就可以了。开发者也不必直接操作任务储存器、执行器以及触发器,因为调度器提供了统一的接口,通过调度器就可以操作组件,比如任务的增删改查。
使用
1、引入需要调度的任务并设置运行
2、添加调度任务并设置时间
根据开发需求选择相应的组件,下面是不同的调度器组件:
- BlockingScheduler 阻塞式调度器:适用于只跑调度器的程序。
- BackgroundScheduler 后台调度器:适用于非阻塞的情况,调度器会在后台独立运行。
- AsyncIOScheduler AsyncIO调度器,适用于应用使用AsnycIO的情况。
- GeventScheduler Gevent调度器,适用于应用通过Gevent的情况。
- TornadoScheduler Tornado调度器,适用于构建Tornado应用。
- TwistedScheduler Twisted调度器,适用于构建Twisted应用。
- QtScheduler Qt调度器,适用于构建Qt应用。