成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

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

這篇文章主要講解了Python任務調度模塊APScheduler的用法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

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

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

在APScheduler中有四個組件:

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

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

BlockingScheduler:當調度器是你應用中唯一要運行的東西時使用。

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

作業(yè)存儲

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

觸發(fā)方式

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

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

cron:cron風格的任務觸發(fā)。

Python任務調度模塊APScheduler的用法

Python任務調度模塊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. 暫停和恢復作業(yè)

暫停作業(yè):

–apscheduler.job.Job.pause()

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

恢復作業(yè):

–apscheduler.job.Job.resume()

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

4. 獲得job列表

獲得調度作業(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. 關閉調度器

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

scheduler.shutdown()

scheduler.shutdown(wait=False)

作業(yè)運行的控制

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

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

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

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

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

廣告

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

成都seo排名網(wǎng)站優(yōu)化
渝中区| 布尔津县| 泗水县| 肇东市| 蚌埠市| 汉沽区| 阿尔山市| 全南县| 安徽省| 安徽省| 阿尔山市| 行唐县| 佛坪县| 黄浦区| 延庆县| 田林县| 呼伦贝尔市| 朝阳区| 明溪县| 玛纳斯县| 苍梧县| 西城区| 鹰潭市| 轮台县| 绥滨县| 大新县| 宁陕县| 包头市| 邯郸市| 漯河市| 荥阳市| 高密市| 建平县| 沧州市| 凤山市| 兴安县| 樟树市| 张北县| 罗平县| 长宁区| 洱源县|