电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python 基于Apscheduler實現定時任務

瀏覽:101日期:2022-07-02 09:58:35
導語

在工作場景遇到了這么一個場景,就是需要定期去執行一個緩存接口,用于同步設備配置。首先想到的就是Linux上的crontab,可以定期,或者間隔一段時間去執行任務。但是如果你想要把這個定時任務作為一個模塊集成到Python項目中,或者想持久化任務,顯然crontab不太適用。Python的APScheduler模塊能夠很好的解決此類問題,所以專門寫這篇文章,從簡單入門開始記錄關于APScheduler最基礎的使用場景,以及解決持久化任務的問題,最后結合其他框架深層次定制定時任務模塊這幾個點入手。

簡單介紹

先簡單介紹一下Apscheduler模塊包含的四種組件:

Trigger觸發器 Job作業 Excutor執行器 Scheduler調度器

大概了解了Apscheduler包含的幾種概念,現在先來看一下一個簡單的示例:

# -*- coding: utf-8 -*-from apscheduler.schedulers.blocking import BlockingSchedulerimport timedef hello(): print(time.strftime('%c'))if __name__ == '__main__': scheduler = BlockingScheduler() scheduler.add_job(hello, ’interval’, seconds=5) scheduler.start()

示例的輸出:

Thu Dec 3 16:01:20 2020Thu Dec 3 16:01:25 2020Thu Dec 3 16:01:30 2020Thu Dec 3 16:01:35 2020Thu Dec 3 16:01:40 2020..........

這個簡單的示例,我們用上面提到幾種組件分析一下運行邏輯:

首先是Scheduler調度器,這個示例使用的BlockingScheduler調度器,在官方文檔中的解釋是,BlockingScheduler適合當你的這個定時任務程序是唯一運行的程序;換言之,則是BlockingScheduler調度器是一個阻塞調度器,當程序運行這種調度器,進程則會阻塞,無法執行其他操作; 其次是Job作業和觸發器,這兩個放在一起講是因為,在定義作業的時候,你就需要選擇一個觸發器,這里選擇的是interval觸發器,這種觸發器會以固定時間間隔運行作業。換言之,為調度器添加一個hello的工作,并以每5秒的時間間隔執行任務。 最后就是執行器,默認是ThreadPoolExcutor執行器,他們將任務中可調用對象交給線程池執行操作,等完成操作后,執行器會通知調度程序。

內置的三種Trigger觸發器類型:

date:特定時間僅運行一次作業 interval: 固定的時間間隔內運行一次作業 cron: 在一天內特定的時間定期運行作業

常見的Scheduler調度器:

BlockingScheduler: 調度程序是流程中唯一運行的東西 BackgroundScheduler: 調度程序在應用程序內部的后臺運行時使用 AsyncIOScheduler: 應用程序使用asyncio模塊 GeventScheduler: 應用程序使用gevent模塊 TornadoScheduler:構建Tornado應用程序時使用 TwistedScheduler: 構建Tornado應用程序時使用 QtScheduler: 在構建QT應用程序時使用

常見的JobStore:

MemoryJobStore MongoDBJobStore SQLAlchemyJobStore RedisJobStore 進階使用

通過上面一個簡單的示例了解大概的工作流程,以及各個組件在整個流程中的作用,以下的示例是Flask Web框架結合使用Apscheduler定時器,定時執行任務。

# -*- coding: utf-8 -*-from flask import Flask, Blueprint, requestfrom apscheduler.executors.pool import ThreadPoolExecutor from apscheduler.schedulers.background import BackgroundSchedulerfrom apscheduler.jobstores.redis import RedisJobStoreimport timeapp = Flask(__name__)executors = {'default': ThreadPoolExecutor(5)}default_redis_jobstore = RedisJobStore(db=2, jobs_key='apschedulers.default_jobs', run_times_key='apschedulers.default_run_times', host = ’127.0.0.1’, port = 6379 )scheduler = BackgroundScheduler(executors=executors)scheduler.add_jobstore(default_redis_jobstore)scheduler.start()def say_hello(): print(time.strftime('%c'))@app.route('/get_job', methods=[’GET’])def get_job(): if scheduler.get_job('say_hello_test'): return 'YES' else: return 'NO'@app.route('/start_job', methods=['GET'])def start_job(): if not scheduler.get_job('say_hello_test'): scheduler.add_job(say_hello, 'interval', seconds=5, id='say_hello_test') return 'Start Scuessfully!' else: return 'Started Failed' @app.route('/remove_job', methods=['GET'])def remove_job(): if scheduler.get_job('say_hello_test'): scheduler.remove_job('say_hello_test') return 'Delete Successfully!' else: return 'Delete Failed'if __name__ == '__main__': app.run(host='127.0.0.1', port=8787, debug=True) 先分析Jobstore,這里使用的是RedisJobstore,將任務序列化存入到Redis數據庫中。這里順便提一下,為什么需要設置作業存儲器,原因是當調度器程序崩潰時,仍然能夠保留作業,當然選擇什么作業存儲器,可以根據具體的工作場景,目前主流的mysql,mongodb,redis,SQLite基本都支持; 然后再看看Scheduler,這里使用的時BackgroundScheduler,因為這里要求調度程序不能阻塞flask程序的正常接收請求,所以選在BackgrounScheduler讓它在開始執行任務時是在后臺運行的,不會阻塞主線程; 最后看看工作的邏輯,這里get_job獲取作業的狀態,查看作業是否存在,start_job則是先判斷作業是否啟動,然后再決定啟動操作,remove_job則是停止作業。而這里的作業定義則是通過interval觸發器,每五秒執行一次say_hello任務;總結

最后總結一下,首先你要設置一個作業存儲器用于在調度程序崩潰重新恢復時,還能夠在作業存儲器中獲取到作業繼續執行;然后你需要設置一個執行器,這個根據作業的類型,比如時一個CPU密集型的任務,那就可以用進程池執行器,默認是用線程池執行器;最后創建配置調度器,啟動調度,可以在啟動前添加作業,也可以在啟動后添加,刪除,獲取作業。(在這里需要明白的一點就是應用程序不會直接去操作作業存儲器,作業或者執行器,而是調度器提供適當的接口來處理這些接口。)

ApScheduler是一個不錯的定時任務庫,能夠動態的添加刪除,同時也支持不同的觸發器類型,這也是它的優勢,相反一些如果是靜態任務,其實可以用如linux的crontab工具去做定時任務。有關這方面的記錄還會持續更新,如果有什么問題,可以提出來,大家一起探討。

以上就是python Apscheduler的使用方法的詳細內容,更多關于python Apscheduler的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 志高装潢官网-苏州老房旧房装修改造-二手房装修翻新 | 杭州中策电线|中策电缆|中策电线|杭州中策电缆|杭州中策电缆永通集团有限公司 | 铝镁锰板厂家_进口钛锌板_铝镁锰波浪板_铝镁锰墙面板_铝镁锰屋面-杭州军晟金属建筑材料 | 减速机三参数组合探头|TSM803|壁挂式氧化锆分析仪探头-安徽鹏宸电气有限公司 | 机床主轴维修|刀塔维修|C轴维修-常州翔高精密机械有限公司 | 物联网卡_物联网卡购买平台_移动物联网卡办理_移动联通电信流量卡通信模组采购平台? | 中开泵,中开泵厂家,双吸中开泵-山东博二泵业有限公司 | 新密高铝耐火砖,轻质保温砖价格,浇注料厂家直销-郑州荣盛窑炉耐火材料有限公司 | 抖音短视频运营_企业网站建设_网络推广_全网自媒体营销-东莞市凌天信息科技有限公司 | 自进式锚杆-自钻式中空注浆锚杆-洛阳恒诺锚固锚杆生产厂家 | 脑钠肽-白介素4|白介素8试剂盒-研域(上海)化学试剂有限公司 | 铝扣板-铝方通-铝格栅-铝条扣板-铝单板幕墙-佳得利吊顶天花厂家 elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 手板_手板模型制作_cnc手板加工厂-东莞天泓 | 长沙广告公司|长沙广告制作设计|长沙led灯箱招牌制作找望城湖南锦蓝广告装饰工程有限公司 | 金属管浮子流量计_金属转子流量计厂家-淮安润中仪表科技有限公司 | 东莞螺杆空压机_永磁变频空压机_节能空压机_空压机工厂批发_深圳螺杆空压机_广州螺杆空压机_东莞空压机_空压机批发_东莞空压机工厂批发_东莞市文颖设备科技有限公司 | 广东燎了网络科技有限公司官网-网站建设-珠海网络推广-高端营销型外贸网站建设-珠海专业h5建站公司「了了网」 | 铸铁平台,大理石平台专业生产厂家_河北-北重机械 | 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 - 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 储气罐,真空罐,缓冲罐,隔膜气压罐厂家批发价格,空压机储气罐规格型号-上海申容压力容器集团有限公司 | 断桥铝破碎机_铝合金破碎机_废铁金属破碎机-河南鑫世昌机械制造有限公司 | 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | LED投光灯-工矿灯-led路灯头-工业灯具 - 山东普瑞斯照明科技有限公司 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 【德信自动化】点胶机_全自动点胶机_自动点胶机厂家_塑料热压机_自动螺丝机-深圳市德信自动化设备有限公司 | 超细|超微气流粉碎机|气流磨|气流分级机|粉体改性机|磨粉机|粉碎设备-山东埃尔派粉体科技 | 布袋式除尘器|木工除尘器|螺旋输送机|斗式提升机|刮板输送机|除尘器配件-泊头市德佳环保设备 | 北京模型公司-工业模型-地产模型-施工模型-北京渝峰时代沙盘模型制作公司 | 大学食堂装修设计_公司餐厅效果图_工厂食堂改造_迈普装饰 | 胃口福饺子加盟官网_新鲜现包饺子云吞加盟 - 【胃口福唯一官网】 | 红酒招商加盟-葡萄酒加盟-进口红酒代理-青岛枞木酒业有限公司 | 实验室pH计|电导率仪|溶解氧测定仪|离子浓度计|多参数水质分析仪|pH电极-上海般特仪器有限公司 | 江苏全风,高压风机,全风环保风机,全风环形高压风机,防爆高压风机厂家-江苏全风环保科技有限公司(官网) | 东莞工厂厂房装修_无尘车间施工_钢结构工程安装-广东集景建筑装饰设计工程有限公司 | AR开发公司_AR增强现实_AR工业_AR巡检|上海集英科技 | 搜活动房网—活动房_集装箱活动房_集成房屋_活动房屋 | 扒渣机,铁水扒渣机,钢水扒渣机,铁水捞渣机,钢水捞渣机-烟台盛利达工程技术有限公司 | 农业仪器网 - 中国自动化农业仪器信息交流平台 | 安徽千住锡膏_安徽阿尔法锡膏锡条_安徽唯特偶锡膏_卡夫特胶水-芜湖荣亮电子科技有限公司 |