網(wǎng)站首頁 編程語言 正文
詳解Python利用APScheduler框架實(shí)現(xiàn)定時(shí)任務(wù)_python
作者:劍客阿良_ALiang ? 更新時(shí)間: 2022-05-03 編程語言背景
最近在做一些python工具的時(shí)候,常常會(huì)碰到定時(shí)器問題,總覺著使用threading.timer或者schedule模塊非常不優(yōu)雅。所以這里給自己做個(gè)記錄,也分享一個(gè)定時(shí)任務(wù)框架APScheduler。具體的架構(gòu)原理就不細(xì)說了,用個(gè)例子說明一下怎么簡(jiǎn)易的使用。
樣例代碼
先上樣例代碼,如下:
#!/user/bin/env python # coding=utf-8 """ @project : csdn @author : 劍客阿良_ALiang @file : apschedule_tool.py @ide : PyCharm @time : 2022-03-02 17:34:17 """ from apscheduler.schedulers.background import BackgroundScheduler from multiprocessing import Process, Queue import time import random # 具體工作實(shí)現(xiàn) def do_job(q: Queue): while True: if not q.empty(): _value = q.get(False) print('{} poll -> {}'.format(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()), _value)) else: break def put_job(q: Queue): while True: _value = str(random.randint(1, 10)) q.put(_value) print('{} put -> {}'.format(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime()), _value)) time.sleep(1) if __name__ == '__main__': q = Queue() scheduler = BackgroundScheduler() # 每隔5秒運(yùn)行一次 scheduler.add_job(do_job, trigger='cron', second='*/5', args=(q,)) scheduler.start() Process(target=put_job, args=(q,)).start()
代碼詳解
1、調(diào)度器的選擇主要取決于編程環(huán)境以及 APScheduler 的用途。主要有以下幾種調(diào)度器:
apscheduler.schedulers.blocking.BlockingScheduler:當(dāng)調(diào)度器是程序中唯一運(yùn)行的東西時(shí)使用,阻塞式。
apscheduler.schedulers.background.BackgroundScheduler:當(dāng)調(diào)度器需要后臺(tái)運(yùn)行時(shí)使用。
apscheduler.schedulers.asyncio.AsyncIOScheduler:當(dāng)程序使用 asyncio 框架時(shí)使用。
apscheduler.schedulers.gevent.GeventScheduler:當(dāng)程序使用 gevent 框架時(shí)使用。
apscheduler.schedulers.tornado.TornadoScheduler:當(dāng)構(gòu)建 Tornado 程序時(shí)使用
apscheduler.schedulers.twisted.TwistedScheduler:當(dāng)構(gòu)建 Twisted 程序時(shí)使用
apscheduler.schedulers.qt.QtScheduler:當(dāng)構(gòu)建 Qt 程序時(shí)使用
個(gè)人覺著BackgroundScheduler已經(jīng)很夠用了,在后臺(tái)啟動(dòng)定時(shí)任務(wù),也不會(huì)阻塞進(jìn)程。
2、trigger后面跟隨的類似linux系統(tǒng)下cron寫法,樣例代碼中是每5秒執(zhí)行一次。
3、這里加了一個(gè)多進(jìn)程通訊的隊(duì)列multiprocessing.Queue,主要是樣例代碼解決的場(chǎng)景是我實(shí)際工作中常碰到的,舉個(gè)栗子:多個(gè)進(jìn)程間通訊,其中一個(gè)進(jìn)程需要定時(shí)獲取另一個(gè)進(jìn)程中的數(shù)據(jù)。可以參考樣例代碼。
執(zhí)行結(jié)果
2022-03-02 19:31:27 put -> 4
2022-03-02 19:31:28 put -> 10
2022-03-02 19:31:29 put -> 1
2022-03-02 19:31:30 poll -> 4
2022-03-02 19:31:30 poll -> 10
2022-03-02 19:31:30 poll -> 1
2022-03-02 19:31:30 put -> 2
2022-03-02 19:31:31 put -> 1
2022-03-02 19:31:32 put -> 6
2022-03-02 19:31:33 put -> 4
2022-03-02 19:31:34 put -> 8
2022-03-02 19:31:35 poll -> 2
2022-03-02 19:31:35 poll -> 1
2022-03-02 19:31:35 poll -> 6
2022-03-02 19:31:35 poll -> 4
2022-03-02 19:31:35 poll -> 8
2022-03-02 19:31:35 put -> 8
2022-03-02 19:31:36 put -> 10
2022-03-02 19:31:37 put -> 7
2022-03-02 19:31:38 put -> 2
2022-03-02 19:31:39 put -> 3
2022-03-02 19:31:40 poll -> 8
2022-03-02 19:31:40 poll -> 10
2022-03-02 19:31:40 poll -> 7
2022-03-02 19:31:40 poll -> 2
2022-03-02 19:31:40 poll -> 3
2022-03-02 19:31:40 put -> 5
Process finished with exit code -1
知識(shí)點(diǎn)補(bǔ)充
APScheduler(advanceded python scheduler)基于Quartz的一個(gè)Python定時(shí)任務(wù)框架,實(shí)現(xiàn)了Quartz的所有功能,使用起來十分方便。提供了基于日期、固定時(shí)間間隔以及crontab類型的任務(wù),并且可以持久化任務(wù)。基于這些功能,我們可以很方便的實(shí)現(xiàn)一個(gè)Python定時(shí)任務(wù)系統(tǒng)。
它有以下三個(gè)特點(diǎn):
- 類似于 Liunx Cron 的調(diào)度程序(可選的開始/結(jié)束時(shí)間)
- 基于時(shí)間間隔的執(zhí)行調(diào)度(周期性調(diào)度,可選的開始/結(jié)束時(shí)間)
- 一次性執(zhí)行任務(wù)(在設(shè)定的日期/時(shí)間運(yùn)行一次任務(wù))
APScheduler有四種組成部分:
- 觸發(fā)器(trigger) 包含調(diào)度邏輯,每一個(gè)作業(yè)有它自己的觸發(fā)器,用于決定接下來哪一個(gè)作業(yè)會(huì)運(yùn)行。除了他們自己初始配置意外,觸發(fā)器完全是無狀態(tài)的。
- 作業(yè)存儲(chǔ)(job store) 存儲(chǔ)被調(diào)度的作業(yè),默認(rèn)的作業(yè)存儲(chǔ)是簡(jiǎn)單地把作業(yè)保存在內(nèi)存中,其他的作業(yè)存儲(chǔ)是將作業(yè)保存在數(shù)據(jù)庫(kù)中。一個(gè)作業(yè)的數(shù)據(jù)講在保存在持久化作業(yè)存儲(chǔ)時(shí)被序列化,并在加載時(shí)被反序列化。調(diào)度器不能分享同一個(gè)作業(yè)存儲(chǔ)。
- 執(zhí)行器(executor) 處理作業(yè)的運(yùn)行,他們通常通過在作業(yè)中提交制定的可調(diào)用對(duì)象到一個(gè)線程或者進(jìn)城池來進(jìn)行。當(dāng)作業(yè)完成時(shí),執(zhí)行器將會(huì)通知調(diào)度器。
- 調(diào)度器(scheduler) 是其他的組成部分。你通常在應(yīng)用只有一個(gè)調(diào)度器,應(yīng)用的開發(fā)者通常不會(huì)直接處理作業(yè)存儲(chǔ)、調(diào)度器和觸發(fā)器,相反,調(diào)度器提供了處理這些的合適的接口。配置作業(yè)存儲(chǔ)和執(zhí)行器可以在調(diào)度器中完成,例如添加、修改和移除作業(yè)。通過配置executor、jobstore、trigger,使用線程池(ThreadPoolExecutor默認(rèn)值20)或進(jìn)程池(ProcessPoolExecutor 默認(rèn)值5)并且默認(rèn)最多3個(gè)(max_instances)任務(wù)實(shí)例同時(shí)運(yùn)行,實(shí)現(xiàn)對(duì)job的增刪改查等調(diào)度控制
示例代碼:
from apscheduler.schedulers.blocking import BlockingScheduler from datetime import datetime # 輸出時(shí)間 def job(): print(datetime.now().strftime("%Y-%m-%d %H:%M:%S")) # BlockingScheduler sched = BlockingScheduler() sched.add_job(my_job, 'interval', seconds=5, id='my_job_id') sched.start()
原文鏈接:https://blog.csdn.net/zhiweihongyan1/article/details/123237008
相關(guān)推薦
- 2023-05-06 C語言順序表的基本結(jié)構(gòu)與實(shí)現(xiàn)思路詳解_C 語言
- 2022-07-24 Android中關(guān)于定時(shí)任務(wù)實(shí)現(xiàn)關(guān)閉訂單問題_Android
- 2022-04-11 項(xiàng)目視圖以及項(xiàng)目小部件的基本用法(View表和Widget表)
- 2022-07-01 python神經(jīng)網(wǎng)絡(luò)Keras實(shí)現(xiàn)GRU及其參數(shù)量_python
- 2022-03-06 C語言動(dòng)態(tài)順序表實(shí)例代碼_C 語言
- 2023-11-11 微信 小程序 在電腦PC端無法加載的解決辦法。電腦微信小程序打不開是怎么回事?電腦微信小程序不能打開
- 2022-05-06 Python如何判斷字符串是否僅包含數(shù)字_python
- 2022-11-14 Hive DQL及優(yōu)化
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支