Python任務(wù)調(diào)度模塊APScheduler的用法-創(chuàng)新互聯(lián)

這篇文章主要講解了Python任務(wù)調(diào)度模塊APScheduler的用法,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。

我們提供的服務(wù)有:成都做網(wǎng)站、成都網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、岳陽ssl等。為上千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的岳陽網(wǎng)站制作公司

APScheduler是一個Python定時任務(wù)框架,使用起來十分方便。提供了基于日期、固定時間間隔以及crontab類型的任務(wù),并且可以持久化任務(wù)、并以daemon方式運行應(yīng)用。

在APScheduler中有四個組件:

  • 觸發(fā)器(trigger)包含調(diào)度邏輯,每一個作業(yè)有它自己的觸發(fā)器,用于決定接下來哪一個作業(yè)會運行。除了他們自己初始配置意外,觸發(fā)器完全是無狀態(tài)的。簡單說就是應(yīng)該說明一個任務(wù)應(yīng)該在什么時候執(zhí)行。
  • 作業(yè)存儲(job store)存儲被調(diào)度的作業(yè),默認的作業(yè)存儲是簡單地把作業(yè)保存在內(nèi)存中,其他的作業(yè)存儲是將作業(yè)保存在數(shù)據(jù)庫中。一個作業(yè)的數(shù)據(jù)將在保存在持久化作業(yè)存儲時被序列化,并在加載時被反序列化。調(diào)度器不能分享同一個作業(yè)存儲。
  • 執(zhí)行器(executor)處理作業(yè)的運行,他們通常通過在作業(yè)中提交制定的可調(diào)用對象到一個線程或者進城池來進行。當(dāng)作業(yè)完成時,執(zhí)行器將會通知調(diào)度器。
  • 調(diào)度器(scheduler)任務(wù)控制器:通過配置executor、jobstore、trigger,使用線程池(ThreadPoolExecutor默認值20)或進程池(ProcessPoolExecutor 默認值5)并且默認最多3個(max_instances)任務(wù)實例同時運行,實現(xiàn)對job的增刪改查等調(diào)度控制

你需要選擇合適的調(diào)度器,這取決于你的應(yīng)用環(huán)境和你使用APScheduler的目的。通常最常用的兩個:

BlockingScheduler:當(dāng)調(diào)度器是你應(yīng)用中唯一要運行的東西時使用。

BackgroundScheduler:當(dāng)你不運行任何其他框架時使用,并希望調(diào)度器在你應(yīng)用的后臺執(zhí)行。

作業(yè)存儲

支持4中作業(yè)存儲,分別是:MemoryJobStore(存儲在內(nèi)存中)、sqlalchemy(關(guān)系型數(shù)據(jù)庫)、mongodb(文檔數(shù)據(jù)庫)、redis(內(nèi)存型鍵值對數(shù)據(jù)庫)

觸發(fā)方式

date:固定日期觸發(fā)器:任務(wù)只運行一次,運行完畢自動清除;若錯過指定運行時間,任務(wù)不會被創(chuàng)建

interval:時間間隔觸發(fā)器,每個一定時間間隔執(zhí)行一次。

cron:cron風(fēng)格的任務(wù)觸發(fā)。

Python任務(wù)調(diào)度模塊APScheduler的用法

Python任務(wù)調(diào)度模塊APScheduler的用法

作業(yè)操作

1. 添加作業(yè):上面是通過add_job()來添加作業(yè),另外還有一種方式是通過scheduled_job()修飾器來修飾函數(shù)。

@sched.scheduled_job('cron', id='my_job_id', day='last sun')

def some_decorated_task():

print("I am printed at 00:00:00 on the last Sunday of every month!")

2. 移除作業(yè)

job = scheduler.add_job(myfunc,'interval', minutes=2)

job.remove()

Same,using an explicit job ID:

scheduler.add_job(myfunc,'interval', minutes=2, id='my_job_id')

scheduler.remove_job('my_job_id')

3. 暫停和恢復(fù)作業(yè)

暫停作業(yè):

–apscheduler.job.Job.pause()

–apscheduler.schedulers.base.BaseScheduler.pause_job()

恢復(fù)作業(yè):

–apscheduler.job.Job.resume()

–apscheduler.schedulers.base.BaseScheduler.resume_job()

4. 獲得job列表

獲得調(diào)度作業(yè)的列表,可以使用get_jobs()來完成,它會返回所有的job實例?;蛘呤褂胮rint_jobs()來輸出所有格式化的作業(yè)列表。

5. 修改作業(yè)

def some_decorated_task():

print("I am printed at 00:00:00 on the last Sunday of every month!")

6. 關(guān)閉調(diào)度器

默認情況下調(diào)度器會等待所有正在運行的作業(yè)完成后,關(guān)閉所有的調(diào)度器和作業(yè)存儲。如果你不想等待,可以將wait選項設(shè)置為False。

scheduler.shutdown()

scheduler.shutdown(wait=False)

作業(yè)運行的控制

add_job的第二個參數(shù)是trigger,它管理著作業(yè)的調(diào)度方式。它可以為date, interval或者cron。對于不同的trigger,對應(yīng)的參數(shù)也相同。

看完上述內(nèi)容,是不是對Python任務(wù)調(diào)度模塊APScheduler的用法有進一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

本文名稱:Python任務(wù)調(diào)度模塊APScheduler的用法-創(chuàng)新互聯(lián)
標題鏈接:http://muchs.cn/article30/diedso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、建站公司企業(yè)網(wǎng)站制作、靜態(tài)網(wǎng)站網(wǎng)站收錄、網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化