日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

python 基于Apscheduler實現定時任務

瀏覽:180日期: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 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
中文字幕在线视频久| 国产精品亚洲四区在线观看| 久久午夜影院| 国产精品v亚洲精品v日韩精品| 三级久久三级久久久| 亚洲精品福利| 青青伊人久久| 国产精品videossex| 欧美激情在线精品一区二区三区| 国产女人18毛片水真多18精品| 国产日韩高清一区二区三区在线| 日本不卡视频在线观看| 国产日韩一区二区三免费高清| 久久不见久久见国语| 国产一区二区三区不卡视频网站 | 老司机精品视频网| 国产精品igao视频网网址不卡日韩| 久久香蕉网站| 91精品国产福利在线观看麻豆| 欧美日韩国产高清电影| 蜜桃视频一区二区三区在线观看| 丝袜美腿成人在线| 欧美一区久久| 欧美片第1页| 欧美综合二区| 国产精品99久久免费观看| 欧美精品日日操| 丝袜美腿成人在线| 国产精品大片| 一区二区三区四区在线看| 中文字幕一区二区三区四区久久| 国产精品片aa在线观看 | 久久中文精品| 欧美亚洲国产精品久久| 亚洲v天堂v手机在线| 国产精品s色| 午夜日韩在线| 国产精品一区二区美女视频免费看 | 蜜臀精品久久久久久蜜臀| 日本精品另类| 日韩综合在线| 中文一区一区三区免费在线观 | 亚洲一二三区视频| 国产精品羞羞答答在线观看| 欧美日韩免费观看视频| 久热re这里精品视频在线6| 国产亚洲一区二区三区啪| 日韩在线观看一区| 日本午夜精品视频在线观看| 日韩精品欧美| 日韩国产一区二| 久久久噜噜噜| 国产欧美日韩在线一区二区 | 亚洲手机在线| 久久精品97| 免费av一区二区三区四区| 欧美日韩精品一区二区三区视频 | 久久久夜夜夜| 88久久精品| 国产一区日韩一区| 国产免费久久| 国产色综合网| 高清av一区| 亚洲精品黄色| 欧美日中文字幕| 九九99久久精品在免费线bt| 丝袜亚洲另类欧美| 神马久久午夜| 国产精品视频一区视频二区| 国产女优一区| 久久精品青草| 国产在视频一区二区三区吞精| 亚洲va久久| 欧美日韩国产亚洲一区| 欧美日韩国产观看视频| 国产精品一区二区精品| 天使萌一区二区三区免费观看| 在线观看精品| 国产精品美女午夜爽爽| 蜜桃视频一区二区三区| 亚洲国产不卡| 成人免费电影网址| 精品网站aaa| 91大神在线观看线路一区| 亚洲在线免费| 1024精品一区二区三区| av资源新版天堂在线| 久久只有精品| 国产精品调教视频| 97成人超碰| 亚洲精品福利| 在线日韩成人| 91久久午夜| 成人精品天堂一区二区三区| 久久影院一区二区三区| 日韩av电影一区| 四虎国产精品免费久久| 国产女优一区| 合欧美一区二区三区| 久久久久久免费视频| 国产一区三区在线播放| 欧美激情一区| 久久99精品久久久野外观看| 午夜久久av| 亚洲免费毛片| 亚洲欧洲日韩| 综合亚洲色图| 亚洲精品国产精品粉嫩| 中文字幕一区二区av| 亚洲涩涩av| 天海翼精品一区二区三区| 亚洲精品福利| 日韩国产一区二| 欧美日韩一区自拍| 国产探花在线精品一区二区| 国产剧情在线观看一区| 国产精品一区二区精品视频观看| 国产欧美日韩影院| 欧美激情视频一区二区三区免费| 国产精品嫩草影院在线看| 国产精品免费大片| 久久字幕精品一区| 亚洲啊v在线| 久久国产影院| 91精品电影| 亚洲免费婷婷| 日本电影久久久| 国产黄色精品| 国产精品成久久久久| 午夜久久中文| 女人天堂亚洲aⅴ在线观看| 老色鬼久久亚洲一区二区| 日本一区二区中文字幕| 国产精品成人一区二区网站软件| 日韩a一区二区| 免费观看久久av| 亚洲免费资源| 欧美成人aaa| av资源中文在线天堂| 成人久久一区| 亚洲综合二区| 91一区二区三区四区| 精品一区毛片| 在线精品福利| 国产精久久久| 久久国产日本精品| 久久av一区| 国产精品一区二区三区四区在线观看 | 欧美国产日本| 精精国产xxxx视频在线播放| 日韩亚洲在线| 日本不卡不码高清免费观看| 久久91视频| 久久激情一区| 亚洲资源网站| 国产成人免费精品| 亚洲成人免费| 日韩精品欧美精品| 成人国产精品久久| 免费黄色成人| 欧美精品国产白浆久久久久| 精品久久电影| 欧美日韩国产在线一区| 国产日韩一区| 国产专区一区| 国产精品美女久久久久久不卡| 91看片一区| 日欧美一区二区| 伊人久久视频| 五月国产精品| 韩国三级一区| 日韩精品久久理论片| 麻豆91精品91久久久的内涵| 亚洲性图久久| 国产精品激情| 91久久国产| 丝瓜av网站精品一区二区| 国产一区二区视频在线看| 国产在线不卡| 不卡专区在线| 亚洲精品免费观看| 精品视频在线一区二区在线| 日韩不卡在线| 黄在线观看免费网站ktv| 亚洲精品极品少妇16p| 99国产精品99久久久久久粉嫩| 亚洲开心激情| 成人免费一区| 亚洲一区二区三区四区五区午夜| 国产精品久久国产愉拍| 鲁大师精品99久久久| а√天堂8资源在线| 男女性色大片免费观看一区二区 | 亚洲精品影视| 国产欧美一区二区三区精品观看 | 国产美女视频一区二区| 久久精品国产免费| 日韩精品视频中文字幕| 日韩在线播放一区二区| 久久久久欧美精品|