好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > python中BackgroundScheduler和BlockingScheduler的區別

python中BackgroundScheduler和BlockingScheduler的區別

熱門標簽:電梯新時達系統外呼顯示e 成都呼叫中心外呼系統哪家強 宿州電話機器人哪家好 無錫智能外呼系統好用嗎 百應電話機器人總部 地圖標注與注銷 西青語音電銷機器人哪家好 旅游廁所地圖標注怎么弄 南昌地圖標注

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

1、基本的定時調度

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

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

from apscheduler.schedulers.blocking import BlockingScheduler

def 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 BlockingScheduler
import time

def 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 3s
job 3s
job 3s
job 3s 

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

BackgroundScheduler例子

from apscheduler.schedulers.background import BackgroundScheduler
import time

def 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 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
job 3s 

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

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

from apscheduler.schedulers.background import BackgroundScheduler
import time

def 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 3s
main 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s

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

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

from apscheduler.schedulers.background import BackgroundScheduler
import time

def 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 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
Execution 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 1s
main 1s
main 1s
job 3s
main 1s

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

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

from apscheduler.schedulers.background import BackgroundScheduler
import time

def 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 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
job 3s
main 1s
main 1s
main 1s
job 3s

每個job是怎么被調度的

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

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

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

from apscheduler.schedulers.background import BackgroundScheduler
import time,os,threading

def 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 1s
main 1s
main 1s
job thread_id-10644, process_id-8872
main 1s
main 1s
main 1s
job thread_id-3024, process_id-8872
main 1s
main 1s
main 1s
job thread_id-6728, process_id-8872
main 1s
main 1s
main 1s
job thread_id-11716, process_id-8872

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

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

您可能感興趣的文章:
  • Python定時任務工具之APScheduler使用方式
  • 詳解Python 定時框架 Apscheduler原理及安裝過程
  • 詳解python調度框架APScheduler使用
  • Python任務調度利器之APScheduler詳解
  • Python使用APScheduler實現定時任務過程解析
  • Python APScheduler執行使用方法詳解
  • Python任務調度模塊APScheduler使用
  • Python定時任務APScheduler原理及實例解析
  • Python定時任務APScheduler安裝及使用解析
  • python 基于Apscheduler實現定時任務

標簽:辛集 濰坊 西安 雅安 七臺河 贛州 渭南 許昌

巨人網絡通訊聲明:本文標題《python中BackgroundScheduler和BlockingScheduler的區別》,本文關鍵詞  python,中,BackgroundScheduler,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python中BackgroundScheduler和BlockingScheduler的區別》相關的同類信息!
  • 本頁收集關于python中BackgroundScheduler和BlockingScheduler的區別的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 春宵苦短少女前进吧| 国产精品久久久久久久久久| 成熟教师| 搞逼视频免费看| 日本男女黄色| 香蕉在线精品视频在线app| vidaa性欧美| 嗯啊慢点太猛了肉h男男| 国产福利在线看| 欧美国产成人亚洲精品无码久久网 | www.51788.cc久久| 国产精品福利社| 女人与公拘交200部| chinese色系videos教师| 女仆扒开腿秘?让人桶爽网站| 玩弄放荡人妇系列短篇视频| 厨房解开奶罩吸奶头高潮小说| 少妇熟女XXXⅩ性猛交影片一级| 全彩调教侵犯H本子全彩4399| 精品成人99一品无码| 西门庆潘金莲H爽文| 男同桌在我内裤里揉搓| 99久久国产精品免费精品35| 国产骚妻| 日本高清视频一区二区| 欧产?日产?国产精品一二| 小说肉np| 久久久久99人妻一区二区三区| 浴室情欲1在线观看| 国产精品萝年轻在线播放| gogo全球高清专业摄影| 四季日韩AⅤ中文无码综合| 老师用美足丝袜脚夹我好爽 | www色.com| 超级教师| 91热久久| 日本高清动作片www网站| 欧美在线播放| 黑人狠狠的挺身进入| 午夜精品久久久久久久99热影院| 午夜欧美日韩在线视频播放|