python定时任务调度——apscheduler模块

一、基本概念

APScheduler(Advanced Python Scheduler),基于Quartz的轻量级Python定时任务调度框架


1.1 四个主要组件:

triggerjobstoresexecutorsscheduler

  • executor 任务执行器:执行任务的模块,不同的IO模型选择相适应的executor

  • jobstore 任务存储仓库:持久存储任务

  • trigger 任务触发器:定义任务按何种条件触发

  • scheduler 任务控制器:通过配置executor、jobstore、trigger,使用线程池(ThreadPoolExecutor默认值20)或进程池(ProcessPoolExecutor 默认值5)并且默认最多3个(max_instances)任务实例同时运行,实现对job的增删改查等调度控制


1.2 七种 scheduler

BlockingScheduler、BackgroundScheduler、AsyncIOScheduler、GeventScheduler、TornadoScheduler、TwistedScheduler、QtScheduler


1.3 四种 jobstore

MemoryJobStore、sqlalchemy、MongoDBRedis


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

  • interval: 时间间隔触发器

  • cron : cron风格的任务触发

二、简单使用方式


2.1 内存存储job

这里写图片描述

:命令行输入python apscheduler_test.py启动程序;按CTRL+Break安全退出程序,但任务不会被清除;按CTRL+C退出程序,同时任务会被清除;可根据需要,选择以何种方式退出程序


2.2 sqlalchemy 存储job

这里写图片描述


:命令行输入python apscheduler_test.py启动程序后,会在当前工作目录生成jobs.sqlite数据库文件;sqlalchemy默认使用SQLite存储job,table名默认为apscheduler_jobs;用SQLite Database Browser打开该文件,各任务显示如下:

这里写图片描述


2.3 mongodb 存储job

这里写图片描述

:运行程序前,确保已开启本机mongodb服务;命令行输入python apscheduler_test.py启动程序;


2.4 事件监听器

这里写图片描述

:命令行输入python apscheduler_test.py启动程序后,得到如下反馈:

这里写图片描述


2.5 BackgroundScheduler

这里写图片描述


参考

[1] https://bitbucket.org/agronholm/apscheduler/src
[2] http://apscheduler.readthedocs.org/en/latest/userguide.html#code-examples
[3] http://www.bubuko.com/infodetail-716148.html

### 使用注解实现 Python 定时任务调度 为了在 Python 中利用注解实现定时任务调度,可以采用 `apscheduler` 库。此库允许通过装饰器定义任务并设置其执行时间表。 #### 导入所需模块 首先安装 `apscheduler`: ```bash pip install apscheduler ``` 接着导入必要的组件: ```python from apscheduler.schedulers.background import BackgroundScheduler from datetime import datetime import time ``` #### 创建带注解的任务函数 下面展示了一个简单的例子,在其中创建了两个带有不同频率的周期性任务,并使用装饰器来指定这些属性。 ```python def job_decorator(func): """A decorator to add cron-like scheduling information.""" func.run_date = 'cron' # Add a property that indicates the function is scheduled. return func @job_decorator def task_1(): print(f'Task 1 executed at {datetime.now()}') @job_decorator def task_2(): print(f'Task 2 executed at {datetime.now()}') ``` 上述代码片段中的 `task_1()` 和 `task_2()` 函数被赋予了一种特殊的标记——即它们应该按照某种计划被执行[^1]。 #### 设置后台调度程序 接下来初始化一个背景调度实例并将之前定义好的任务加入到这个调度里去: ```python sched = BackgroundScheduler() # Schedule jobs using properties added by decorators if hasattr(task_1, 'run_date'): sched.add_job(task_1, trigger='interval', seconds=5) if hasattr(task_2, 'run_date'): sched.add_job(task_2, trigger='interval', minutes=1) sched.start() ``` 这段逻辑检查是否有特定属性存在 (`run_date`) 来判断是否要将该方法注册成定期运行的工作项;然后根据实际需求调整参数以适应不同的调度模式 (比如每五秒一次 vs 每分钟一次)[^4]。 最后保持主线程存活以便让其他线程能够继续工作直到手动停止它为止: ```python try: while True: time.sleep(2) except KeyboardInterrupt: sched.shutdown(wait=False) ``` 这样就完成了一个基于注解驱动的简单版Python定时任务框架的设计与实现了[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值