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

您的位置:首頁技術(shù)文章
文章詳情頁

python中BackgroundScheduler和BlockingScheduler的區(qū)別

瀏覽:27日期:2022-07-28 08:23:25
目錄1、基本的定時(shí)調(diào)度2、BlockingScheduler與BackgroundScheduler區(qū)別

APScheduler最基本的用法: “定時(shí)幾秒后啟動job”兩種調(diào)度器: BackgroundScheduler和BlockingScheduler的區(qū)別,job執(zhí)行時(shí)間大于定時(shí)調(diào)度時(shí)間特殊情況的問題及解決方法每個(gè)job都會以thread的方式被調(diào)度。

1、基本的定時(shí)調(diào)度

APScheduler是python的一個(gè)定時(shí)任務(wù)調(diào)度框架,能實(shí)現(xiàn)類似linux下crontab類型的任務(wù),使用起來比較方便。它提供基于固定時(shí)間間隔、日期以及crontab配置類似的任務(wù)調(diào)度,并可以持久化任務(wù),或?qū)⑷蝿?wù)以daemon方式運(yùn)行。

下面是一個(gè)最基本的使用示例:

from apscheduler.schedulers.blocking import BlockingSchedulerdef job(): print(’job 3s’)if __name__==’__main__’: sched = BlockingScheduler(timezone=’MST’) sched.add_job(job, ’interval’, id=’3_second_job’, seconds=3) sched.start()

它能實(shí)現(xiàn)每隔3s就調(diào)度job()運(yùn)行一次,所以程序每隔3s就輸出’job 3s’。通過修改add_job()的參數(shù)seconds,就可以改變?nèi)蝿?wù)調(diào)度的間隔時(shí)間。

2、BlockingScheduler與BackgroundScheduler區(qū)別

APScheduler中有很多種不同類型的調(diào)度器,BlockingScheduler與BackgroundScheduler是其中最常用的兩種調(diào)度器。那他們之間有什么區(qū)別呢? 簡單來說,區(qū)別主要在于BlockingScheduler會阻塞主線程的運(yùn)行,而BackgroundScheduler不會阻塞。所以,我們在不同的情況下,選擇不同的調(diào)度器:

BlockingScheduler: 調(diào)用start函數(shù)后會阻塞當(dāng)前線程。當(dāng)調(diào)度器是你應(yīng)用中唯一要運(yùn)行的東西時(shí)(如上例)使用。BackgroundScheduler: 調(diào)用start后主線程不會阻塞。當(dāng)你不運(yùn)行任何其他框架時(shí)使用,并希望調(diào)度器在你應(yīng)用的后臺執(zhí)行。下面用兩個(gè)例子來更直觀的說明兩者的區(qū)別。

BlockingScheduler例子

from apscheduler.schedulers.blocking import BlockingSchedulerimport timedef job(): print(’job 3s’)if __name__==’__main__’: sched = BlockingScheduler(timezone=’MST’) sched.add_job(job, ’interval’, id=’3_second_job’, seconds=3) sched.start() while(True): # 不會被執(zhí)行到print(’main 1s’)time.sleep(1)

運(yùn)行這個(gè)程序,我們得到如下的輸出:

job 3sjob 3sjob 3sjob 3s

可見,BlockingScheduler調(diào)用start函數(shù)后會阻塞當(dāng)前線程,導(dǎo)致主程序中while循環(huán)不會被執(zhí)行到。

BackgroundScheduler例子

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job(): print(’job 3s’)if __name__==’__main__’: sched = BackgroundScheduler(timezone=’MST’) sched.add_job(job, ’interval’, id=’3_second_job’, seconds=3) sched.start() while(True):print(’main 1s’)time.sleep(1)

可見,BackgroundScheduler調(diào)用start函數(shù)后并不會阻塞當(dāng)前線程,所以可以繼續(xù)執(zhí)行主程序中while循環(huán)的邏輯。

main 1smain 1smain 1sjob 3smain 1smain 1smain 1sjob 3s

通過這個(gè)輸出,我們也可以發(fā)現(xiàn),調(diào)用start函數(shù)后,job()并不會立即開始執(zhí)行。而是等待3s后,才會被調(diào)度執(zhí)行。如何讓job在start()后就開始運(yùn)行如何才能讓調(diào)度器調(diào)用start函數(shù)后,job()就立即開始執(zhí)行呢?

其實(shí)APScheduler并沒有提供很好的方法來解決這個(gè)問題,但有一種最簡單的方式,就是在調(diào)度器start之前,就運(yùn)行一次job(),如下

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job(): print(’job 3s’)if __name__==’__main__’: job() # 執(zhí)行一次就好了喲 sched = BackgroundScheduler(timezone=’MST’) sched.add_job(job, ’interval’, id=’3_second_job’, seconds=3) sched.start() while(True):print(’main 1s’)time.sleep(1)

這樣就能得到如下的輸出

job 3smain 1smain 1smain 1sjob 3smain 1smain 1smain 1s

這樣雖然沒有絕對做到“讓job在start()后就開始運(yùn)行”,但也能做到“不等待調(diào)度,而是剛開始就運(yùn)行job”。

如果job執(zhí)行時(shí)間過長會怎么樣如果執(zhí)行job()的時(shí)間需要5s,但調(diào)度器配置為每隔3s就調(diào)用一下job(),會發(fā)生什么情況呢?我們寫了如下例子:

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job(): print(’job 3s’) time.sleep(5)if __name__==’__main__’: sched = BackgroundScheduler(timezone=’MST’) sched.add_job(job, ’interval’, id=’3_second_job’, seconds=3) sched.start() while(True):print(’main 1s’)time.sleep(1)

運(yùn)行這個(gè)程序,我們得到如下的輸出:

main 1smain 1smain 1sjob 3smain 1smain 1smain 1sExecution of job 'job (trigger: interval[0:00:03], next run at: 2018-05-07 02:44:29 MST)' skipped: maximum number of running instances reached (1)main 1smain 1smain 1sjob 3smain 1s

可見,3s時(shí)間到達(dá)后,并不會“重新啟動一個(gè)job線程”,而是會跳過該次調(diào)度,等到下一個(gè)周期(再等待3s),又重新調(diào)度job()。

為了能讓多個(gè)job()同時(shí)運(yùn)行,我們也可以配置調(diào)度器的參數(shù)max_instances,如下例,我們允許2個(gè)job()同時(shí)運(yùn)行:

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job(): print(’job 3s’) time.sleep(5)if __name__==’__main__’: job_defaults = { ’max_instances’: 2 } sched = BackgroundScheduler(timezone=’MST’, job_defaults=job_defaults) sched.add_job(job, ’interval’, id=’3_second_job’, seconds=3) sched.start() while(True):print(’main 1s’)time.sleep(1)

運(yùn)行程序,我們得到如下的輸出:

main 1smain 1smain 1sjob 3smain 1smain 1smain 1sjob 3smain 1smain 1smain 1sjob 3s

每個(gè)job是怎么被調(diào)度的

通過上面的例子,我們發(fā)現(xiàn),調(diào)度器是定時(shí)調(diào)度job()函數(shù),來實(shí)現(xiàn)調(diào)度的。

那job()函數(shù)會被以進(jìn)程的方式調(diào)度運(yùn)行,還是以線程來運(yùn)行呢?

為了弄清這個(gè)問題,我們寫了如下程序:

from apscheduler.schedulers.background import BackgroundSchedulerimport time,os,threadingdef job(): print(’job thread_id-{0}, process_id-{1}’.format(threading.get_ident(), os.getpid())) time.sleep(50)if __name__==’__main__’: job_defaults = { ’max_instances’: 20 } sched = BackgroundScheduler(timezone=’MST’, job_defaults=job_defaults) sched.add_job(job, ’interval’, id=’3_second_job’, seconds=3) sched.start() while(True):print(’main 1s’)time.sleep(1)

運(yùn)行程序,我們得到如下的輸出:

main 1smain 1smain 1sjob thread_id-10644, process_id-8872main 1smain 1smain 1sjob thread_id-3024, process_id-8872main 1smain 1smain 1sjob thread_id-6728, process_id-8872main 1smain 1smain 1sjob thread_id-11716, process_id-8872

可見,每個(gè)job()的進(jìn)程ID都相同,但線程ID不同。所以,job()最終是以線程的方式被調(diào)度執(zhí)行。

到此這篇關(guān)于python中BackgroundScheduler和BlockingScheduler的區(qū)別 的文章就介紹到這了,更多相關(guān)python BackgroundScheduler BlockingScheduler內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
98精品久久久久久久| 欧美日韩免费观看一区=区三区 | 国产一区二区精品久| 在线观看亚洲精品福利片| 99精品国产一区二区三区| 成人污污视频| 精品一区av| 欧美视频一区| 日韩av午夜在线观看| 日韩精品一区第一页| 国产精品日本一区二区不卡视频| 欧美在线资源| 色偷偷偷在线视频播放| 青草综合视频| 久久av在线| 亚洲精品电影| 91九色精品国产一区二区| 久久久久99| 欧美成人精品三级网站| 中文在线а√天堂| 97人人精品| 中文字幕成在线观看| 国精品产品一区| 久久久91麻豆精品国产一区| 日韩高清成人在线| 日韩精品第二页| 亚洲最新av| 视频一区二区三区在线| 亚洲欧美日本国产专区一区| 久久午夜影视| 亚洲最新av| 日韩欧美另类中文字幕| 日韩国产在线观看一区| 日本aⅴ亚洲精品中文乱码| 日韩激情中文字幕| 欧美天堂在线| 精品国产一区二区三区性色av| 国产精品天堂蜜av在线播放| 欧美性www| 你懂的国产精品| 精品一区91| 精品国产一区二区三区性色av| 日韩福利视频一区| 久久国产精品免费一区二区三区 | 岛国av在线播放| 99精品在线观看| 欧美丝袜一区| 亚洲一区免费| 日韩精品亚洲专区| 国产精品日本一区二区不卡视频| 精品久久久亚洲| 99久久久久国产精品| 先锋亚洲精品| 一区二区精彩视频| 美日韩一区二区三区| 精品国产99| 亚洲一级二级| 一区二区三区网站| 国产精品视频一区二区三区 | 国产精品巨作av| 国产精品美女午夜爽爽| 久久精品av| 六月天综合网| 岛国精品一区| 精品国产免费人成网站| 欧美专区一区二区三区| 国产日本精品| 国产一区二区三区探花| 免费视频久久| 美女视频黄免费的久久| 亚洲国产一区二区在线观看| 日韩精品免费观看视频| 国产精品二区不卡| 亚洲自啪免费| 国产精品啊v在线| 99精品在线观看| 日韩精品高清不卡| 91亚洲国产成人久久精品| 亚洲免费婷婷| 国产麻豆一区| 久久激情一区| 日韩二区在线观看| 亚洲成人国产| 日韩国产欧美三级| av综合电影网站| 日韩欧美中文字幕在线视频| 精品亚洲精品| 丝袜亚洲另类欧美| 国产激情在线播放| 亚洲精品无播放器在线播放| 中文字幕人成乱码在线观看| 亚洲综合五月| 久久久久黄色| 久久中文字幕av一区二区不卡| 日韩在线网址| 欧美中文一区二区| 欧美国产极品| 免费视频一区二区| 日韩国产欧美一区二区| 日本成人在线一区| 欧美影院三区| 美女视频黄久久| 综合国产视频| 久久一级电影| 免费视频一区二区三区在线观看| 合欧美一区二区三区| 麻豆国产一区| 人人爽香蕉精品| 欧美日韩国产v| 日韩一区二区三区在线看| 日本久久成人网| 久久国产人妖系列| 亚洲精品极品少妇16p| 国产色播av在线| 国产精品伊人| 美女尤物久久精品| 五月天av在线| 欧美91在线|欧美| 影音先锋久久精品| 五月天久久网站| sm久久捆绑调教精品一区| 国产欧美高清视频在线| 亚洲最大av| 亚洲激情另类| av在线最新| 国产精品欧美三级在线观看| 免费人成网站在线观看欧美高清| 日韩欧美精品| 福利片在线一区二区| 国产精品99久久免费观看| 日本伊人午夜精品| 久久国产精品亚洲77777| 久久影院一区| 欧美片第1页| zzzwww在线看片免费| 美腿丝袜亚洲三区| 国产乱码精品一区二区三区四区| 伊人国产精品| 久久av一区| 欧美福利一区| 久久精品免费一区二区三区 | 亚洲精品观看| 蜜桃久久精品一区二区| av高清不卡| 国产专区精品| 黄色精品视频| 国产在线观看91一区二区三区| 欧美久久亚洲| 日韩av二区在线播放| 日本中文字幕不卡| 亚洲永久字幕| 九九综合在线| 久久视频精品| 亚洲成人不卡| 成人福利视频| 欧美好骚综合网| 精品国产不卡| 国产劲爆久久| 日韩欧美另类中文字幕| 在线精品福利| 日韩成人一级| 欧美日韩夜夜| 国产经典一区| 国产成人精品一区二区三区免费| 国产精品精品| 久久国产欧美| 亚洲免费福利| 韩国精品主播一区二区在线观看| 日韩一区电影| 亚洲精品97| 亚洲视频二区| 91成人福利| 国产一区调教| 神马午夜久久| 一区免费视频| 免费一区二区视频| 青青伊人久久| 久久香蕉网站| 久久久久一区| 亚洲一级在线| 日本一区免费网站| 日韩高清三区| 精品亚洲二区| 激情六月综合| 亚洲一二av| 国产精品videossex久久发布| 国产一区二区三区亚洲| 久久久久美女| 蜜臀av国产精品久久久久| 久久国产精品毛片| 日本成人精品| 国产一区二区三区亚洲| www.com.cn成人| 99久久亚洲精品蜜臀| 视频精品一区二区| 亚洲综合婷婷| 亚洲精品字幕| 久久亚洲欧美| 亚洲一区二区av| 精品久久久久中文字幕小说|