flask-apscheduler的使用
Flask-APScheduler是根据APScheduler编写的一个flask模块,它提供了API管理任务。
Advanced Python Scheduler(APScheduler)是一个Python库,可让Python代码稍后执行,一次或定期执行。
安装
1 | pip install Flask-APScheduler |
配置
可以参考githup的范列
test.py
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 | from flask import Flask from apscheduler.schedulers.background import BackgroundScheduler from flask_apscheduler import APScheduler '' 'flask_apscheduler的JOBS可以在Config中配置, 也可以通过装饰器调用,还可以通过flask_apschedule的api进行添加 job stores 默认为内存, 可以下在flask的Config中配置为存储在数据库中 '' ' class Config(object): # JOBS可以在配置里面配置 JOBS = [{ 'id' : 'job1' , 'func' : 'test:job1' , 'args' : (1, 2), 'trigger' : 'interval' , 'seconds' : 10 }] SCHEDULER_TIMEZONE = 'Asia/Shanghai' # 配置时区 SCHEDULER_API_ENABLED = True # 添加API # 配置job store # DATABASE_URL="mysql+pymysql://scott:xxxx@192.168.0.95:3306/test?charset=utf8mb4" # SCHEDULER_JOBSTORES = { # 'default': SQLAlchemyJobStore(url=DATABASE_URL) # } # 初始化调度器 scheduler = APScheduler(BackgroundScheduler(timezone= "Asia/Shanghai" )) def job1(a, b): print(str(a) + ' ' + str(b)) # 使用装饰器调用 @scheduler.task( 'interval' , id = 'job_2' , seconds=30, misfire_grace_time=900) def job2(): print( 'Job 2 executed' ) if __name__ == '__main__' : app = Flask(__name__) app.config.from_object(Config()) # it is also possible to enable the API directly # scheduler.api_enabled = True scheduler.init_app(app) scheduler.start() app.run(host= '0.0.0.0' , port=5000) |
schedule的三种运行时间设置
安排工作时,需要为其选择一个触发器。触发器确定运行作业时通过其计算日期/时间的逻辑。APScheduler带有三种内置的触发器类型:
1 2 3 | scheduler.add_job(func=job2, args=( '定时任务' ,), trigger= 'cron' , second= '*/5' ) scheduler.add_job(func=job2, args=( '一次性任务' ,), next_run_time=datetime.datetime.now() + datetime.timedelta(seconds=12)) scheduler.add_job(func=job2, args=( '循环任务' ,), trigger= 'interval' , seconds=3) |
Flask-APSchedule提供的API
1 2 3 4 5 6 7 8 9 | scheduler.add_job POST /scheduler/jobs scheduler.delete_job DELETE /scheduler/jobs/ <job_id> scheduler.get_job GET /scheduler/jobs/ <job_id> scheduler.get_jobs GET /scheduler/jobs scheduler.get_scheduler_info GET /scheduler scheduler.pause_job POST /scheduler/jobs/ <job_id> /pause scheduler.resume_job POST /scheduler/jobs/ <job_id> /resume scheduler.run_job POST /scheduler/jobs/ <job_id> /run scheduler.update_job PATCH /scheduler/jobs/ <job_id> |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2019-10-23 Redis安装配置
2016-10-23 JavaWeb学习总结(二)—http协议
2016-10-23 JavaWeb学习总结(一)—JavaWeb开发入门及环境搭建