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

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

python中BackgroundScheduler和BlockingScheduler的區別

瀏覽:29日期:2022-07-28 08:23:25
目錄1、基本的定時調度2、BlockingScheduler與BackgroundScheduler區別

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

1、基本的定時調度

APScheduler是python的一個定時任務調度框架,能實現類似linux下crontab類型的任務,使用起來比較方便。它提供基于固定時間間隔、日期以及crontab配置類似的任務調度,并可以持久化任務,或將任務以daemon方式運行。

下面是一個最基本的使用示例:

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()

它能實現每隔3s就調度job()運行一次,所以程序每隔3s就輸出’job 3s’。通過修改add_job()的參數seconds,就可以改變任務調度的間隔時間。

2、BlockingScheduler與BackgroundScheduler區別

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

BlockingScheduler: 調用start函數后會阻塞當前線程。當調度器是你應用中唯一要運行的東西時(如上例)使用。BackgroundScheduler: 調用start后主線程不會阻塞。當你不運行任何其他框架時使用,并希望調度器在你應用的后臺執行。下面用兩個例子來更直觀的說明兩者的區別。

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): # 不會被執行到print(’main 1s’)time.sleep(1)

運行這個程序,我們得到如下的輸出:

job 3sjob 3sjob 3sjob 3s

可見,BlockingScheduler調用start函數后會阻塞當前線程,導致主程序中while循環不會被執行到。

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調用start函數后并不會阻塞當前線程,所以可以繼續執行主程序中while循環的邏輯。

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

通過這個輸出,我們也可以發現,調用start函數后,job()并不會立即開始執行。而是等待3s后,才會被調度執行。如何讓job在start()后就開始運行如何才能讓調度器調用start函數后,job()就立即開始執行呢?

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

from apscheduler.schedulers.background import BackgroundSchedulerimport timedef job(): print(’job 3s’)if __name__==’__main__’: job() # 執行一次就好了喲 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()后就開始運行”,但也能做到“不等待調度,而是剛開始就運行job”。

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

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)

運行這個程序,我們得到如下的輸出:

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時間到達后,并不會“重新啟動一個job線程”,而是會跳過該次調度,等到下一個周期(再等待3s),又重新調度job()。

為了能讓多個job()同時運行,我們也可以配置調度器的參數max_instances,如下例,我們允許2個job()同時運行:

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)

運行程序,我們得到如下的輸出:

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

每個job是怎么被調度的

通過上面的例子,我們發現,調度器是定時調度job()函數,來實現調度的。

那job()函數會被以進程的方式調度運行,還是以線程來運行呢?

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

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)

運行程序,我們得到如下的輸出:

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

可見,每個job()的進程ID都相同,但線程ID不同。所以,job()最終是以線程的方式被調度執行。

到此這篇關于python中BackgroundScheduler和BlockingScheduler的區別 的文章就介紹到這了,更多相關python BackgroundScheduler BlockingScheduler內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美一级二级视频| 日韩av不卡在线观看| 成人国产精品久久| 久久久久亚洲精品中文字幕| 久久久免费人体| 久久影院资源站| 麻豆视频久久| 欧美一区激情| 亚洲精品观看| 首页欧美精品中文字幕| 久久影院资源站| 精品亚洲成人| 97欧美在线视频| 91亚洲国产成人久久精品| 狂野欧美性猛交xxxx| 激情综合婷婷| 日韩毛片在线| 亚洲高清激情| 美女日韩在线中文字幕| 蜜桃91丨九色丨蝌蚪91桃色 | 欧美在线首页| 精品日产乱码久久久久久仙踪林| 极品av在线| 日韩视频一区| 日韩国产在线观看一区| 美女高潮久久久| 日韩免费福利视频| 香蕉久久夜色精品国产| 免费在线看一区| 国产欧美69| 97精品97| 久久夜色精品| 国产极品一区| 在线日韩av| 日韩一二三区在线观看| 精品三级在线| 精品91久久久久| 日韩国产在线一| 激情国产在线| 美女国产精品| 国内自拍视频一区二区三区| 激情综合网五月| 国产日韩一区二区三区在线| 97精品国产| 在线观看一区| 色一区二区三区四区| 在线亚洲成人| 国产一区二区三区黄网站| 最新日韩欧美| 免费在线观看一区| 一区在线视频观看| 国产欧美日韩精品一区二区免费| 日韩久久一区二区三区| 日韩欧乱色一区二区三区在线| 岛国av在线网站| 久久亚洲精品伦理| 国产aⅴ精品一区二区四区| 日韩一区精品视频| 麻豆国产一区| 午夜在线一区| 国产精品xx| 日韩三区四区| 亚洲成人国产| 免费日韩成人| 蜜臀精品久久久久久蜜臀| 国产一区二区三区国产精品| 蜜桃视频一区二区| 欧美sss在线视频| 国产精品久久久久久久免费软件| 亚洲精品97| 国产aⅴ精品一区二区三区久久| 亚洲网址在线观看| 欧美福利一区| 精品国产美女a久久9999| 日韩专区一卡二卡| 亚洲一级二级| 欧美好骚综合网| 欧美国产先锋| 色8久久久久| 黄色亚洲免费| 国产成人精品亚洲日本在线观看| 国产乱码精品一区二区三区四区 | 午夜欧美精品| 成人亚洲精品| 国产欧美一区二区精品久久久 | 男人操女人的视频在线观看欧美| 日本国产精品| 高清久久精品| 美女毛片一区二区三区四区最新中文字幕亚洲 | 久久亚洲道色| 日韩欧美中文在线观看| 99在线精品免费视频九九视| 国产亚洲一区二区手机在线观看 | 久久狠狠亚洲综合| 伊人国产精品| 国产精品日本| 亚洲国产专区校园欧美| 日韩精品第一区| 精品资源在线| 美女视频黄免费的久久| 91福利精品在线观看| 免费在线观看日韩欧美| 亚洲二区三区不卡| 秋霞影视一区二区三区| а√天堂中文在线资源8| 麻豆久久一区| 国产精品一区二区精品视频观看| 日本成人在线不卡视频| 亚洲精品极品| 婷婷综合成人| 国产在线|日韩| 国内亚洲精品| 欧美日韩一二| 午夜欧美理论片| 国产精品毛片在线| 国产一区91| 石原莉奈一区二区三区在线观看| 欧美专区一区二区三区| 国产精品人人爽人人做我的可爱| 99视频一区| 日韩精品一区第一页| 在线国产日韩| 亚洲1区在线| 97久久亚洲| 国产高清精品二区| 国产 日韩 欧美 综合 一区| 精品国产免费人成网站| 性欧美videohd高精| 91精品国产调教在线观看| 久久精品电影| 红桃视频亚洲| 亚洲aa在线| 国产免费久久| 成人污污视频| 欧美sss在线视频| 婷婷综合亚洲| 亚洲天堂日韩在线| 亚洲精品精选| 国产精品白丝一区二区三区| 久久亚洲黄色| 香蕉成人av| 国产午夜精品一区二区三区欧美| 老鸭窝亚洲一区二区三区| 亚洲三级视频| 国产精品一在线观看| 精品久久中文| 999久久久亚洲| 视频在线在亚洲| 久久国产三级精品| jizzjizz中国精品麻豆| 激情综合网五月| 日韩极品在线观看| 美腿丝袜亚洲一区| 久久精品99久久无色码中文字幕| 亚洲中午字幕| 国产日韩一区二区三区在线| 精品久久国产一区| 国产一区清纯| 91成人在线| av高清一区| 久久成人国产| 欧美精品国产一区| 日韩在线短视频| 日韩精品一区第一页| 国产精品chinese| 激情综合自拍| 欧美日韩a区| 日韩精品2区| 亚洲精品在线a| 国产精品99久久精品| 在线观看免费一区二区| 日本午夜免费一区二区| 成人福利视频| 日韩一区二区三区四区五区| 国产精品久久久久久久久久10秀| 在线亚洲激情| 欧美a级一区二区| 亚洲国产日韩欧美在线| 国产三级一区| 欧美在线资源| 久久精品国产久精国产| 99pao成人国产永久免费视频| 日本久久二区| 99久久婷婷| 国产精品mm| 水野朝阳av一区二区三区| 岛国精品一区| 日本亚洲视频| 日韩精品dvd| 7777精品| 亚洲二区免费| 麻豆精品蜜桃视频网站| 国产一级久久| 国产网站在线| 91精品啪在线观看国产爱臀| 久久国产中文字幕| 国产精品久久久久久久久久白浆| 久久精品欧美一区| 国产精品亚洲片在线播放| 先锋影音久久久|