APScheduler之定时任务工具
APScheduler概述
APScheduler (advanceded python scheduler)是一款Python开发的定时任务工具。
文档地址 https://apscheduler.readthedocs.io/en/latest/userguide.html#starting-the-scheduler
特点:
不依赖于Linux系统的crontab系统定时,独立运行
可以动态添加新的定时任务,如
下单后30分钟内必须支付,否则取消订单,就可以借助此工具(每下一单就要添加此订单的定时任务)
对添加的定时任务可以做持久保存
1.安装
1 | pip install apscheduler |
2.使用方式
1 | from apscheduler.schedulers.background import BackgroundScheduler |
3.调度器Scheduler
负责管理定时任务
- BlockingScheduler: 作为独立进程时使用
1 | from apscheduler.schedulers.blocking import BlockingScheduler |
- BackgroundScheduler: 在框架程序(如Django、Flask)中使用
1 | from apscheduler.schedulers.background import BackgroundScheduler |
4.执行器 executors
在定时任务该执行时,以进程或线程方式执行任务
- ThreadPoolExecutor
1 | from apscheduler.executors.pool import ThreadPoolExecutor |
使用方法
1 | executors = { |
- ProcessPoolExecutor
1 | from apscheduler.executors.pool import ProcessPoolExecutor |
使用方法
1 | executors = { |
5.触发器 Trigger
指定定时任务执行的时机
1) date 在特定的时间日期执行
1 | from datetime import date |
2) interval 经过指定的时间间隔执行
- weeks (int) – number of weeks to wait
- days (int) – number of days to wait
- hours (int) – number of hours to wait
- minutes (int) – number of minutes to wait
- seconds (int) – number of seconds to wait
- start_date (datetime|str) – starting point for the interval calculation
- end_date (datetime|str) – latest possible date/time to trigger on
- timezone (datetime.tzinfo|str) – time zone to use for the date/time calculations
1 | from datetime import datetime |
3) cron 按指定的周期执行
- year (int|str) – 4-digit year
- month (int|str) – month (1-12)
- day (int|str) – day of the (1-31)
- week (int|str) – ISO week (1-53)
- day_of_week (int|str) – number or name of weekday (0-6 or mon,tue,wed,thu,fri,sat,sun)
- hour (int|str) – hour (0-23)
- minute (int|str) – minute (0-59)
- second (int|str) – second (0-59)
- start_date (datetime|str) – earliest possible date/time to trigger on (inclusive)
- end_date (datetime|str) – latest possible date/time to trigger on (inclusive)
- timezone (datetime.tzinfo|str) – time zone to use for the date/time calculations (defaults to scheduler timezone)
1 | # 在6、7、8、11、12月的第三个周五的00:00, 01:00, 02:00和03:00 执行 |
6. 配置方法
方法1
1 | from apscheduler.schedulers.background import BackgroundScheduler |
方法2
1 | from pytz import utc |
7. 启动
1 | scheduler.start() |
- 对于BlockingScheduler ,程序会阻塞在这,防止退出
- 对于BackgroundScheduler,程序会立即返回,后台运行
8.扩展
任务管理
方式一
1 | job = scheduler.add_job(myfunc, 'interval', minutes=2) # 添加任务 |
方式二
1 | scheduler.add_job(myfunc, 'interval', minutes=2, id='my_job_id') # 添加任务 |
调整任务调度周期
1 | job.modify(max_instances=6, name='Alternate name') |
停止APScheduler运行
1 | scheduler.shutdown() |