电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

python中BackgroundScheduler和BlockingScheduler的區別

瀏覽:8日期: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 編程
相關文章:
主站蜘蛛池模板: 成都租车_成都租车公司_成都租车网_众行宝 | 七维官网-水性工业漆_轨道交通涂料_钢结构漆 | 注浆压力变送器-高温熔体传感器-矿用压力传感器|ZHYQ朝辉 | 报警器_家用防盗报警器_烟雾报警器_燃气报警器_防盗报警系统厂家-深圳市刻锐智能科技有限公司 | 无菌检查集菌仪,微生物限度仪器-苏州长留仪器百科 | 新疆系统集成_新疆系统集成公司_系统集成项目-新疆利成科技 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 宠物店加盟_宠物连锁店_开宠物店-【派多格宠物】 | 开锐教育-学历提升-职称评定-职业资格培训-积分入户 | 特种阀门-调节阀门-高温熔盐阀-镍合金截止阀-钛阀门-高温阀门-高性能蝶阀-蒙乃尔合金阀门-福建捷斯特阀门制造有限公司 | 论文查重_免费论文查重_知网学术不端论文查重检测系统入口_论文查重软件 | 上海租车公司_上海包车_奔驰租赁_上海商务租车_上海谐焕租车 | 刹车盘机床-刹车盘生产线-龙口亨嘉智能装备 | 东莞螺丝|东莞螺丝厂|东莞不锈钢螺丝|东莞组合螺丝|东莞精密螺丝厂家-东莞利浩五金专业紧固件厂家 | 滚珠丝杆升降机_螺旋升降机_丝杠升降机-德迈传动 | 液压油缸-液压站生产厂家-洛阳泰诺液压科技有限公司 | 幂简集成 - 品种超全的API接口平台, 一站搜索、试用、集成国内外API接口 | 塑胶跑道_学校塑胶跑道_塑胶球场_运动场材料厂家_中国塑胶跑道十大生产厂家_混合型塑胶跑道_透气型塑胶跑道-广东绿晨体育设施有限公司 | 电缆接头_防水接头_电缆防水接头 - 乐清市新豪电气有限公司 | 郑州墨香品牌设计公司|品牌全案VI设计公司 | 浙江华锤电器有限公司_地磅称重设备_防作弊地磅_浙江地磅售后维修_无人值守扫码过磅系统_浙江源头地磅厂家_浙江工厂直营地磅 | 隧道烘箱_隧道烘箱生产厂家-上海冠顶专业生产烘道设备 | Type-c防水母座|贴片母座|耳机接口|Type-c插座-深圳市步步精科技有限公司 | 车充外壳,车载充电器外壳,车载点烟器外壳,点烟器连接头,旅行充充电器外壳,手机充电器外壳,深圳市华科达塑胶五金有限公司 | 铝镁锰板厂家_进口钛锌板_铝镁锰波浪板_铝镁锰墙面板_铝镁锰屋面-杭州军晟金属建筑材料 | 高低温试验箱-模拟高低温试验箱订制-北京普桑达仪器科技有限公司【官网】 | 储能预警-储能消防系统-电池舱自动灭火装置-四川千页科技股份有限公司官网 | 媒介云-全网整合营销_成都新闻媒体发稿_软文发布平台 | 生物风-销售载体,基因,质粒,ATCC细胞,ATCC菌株等,欢迎购买-百风生物 | 海外整合营销-独立站营销-社交媒体运营_广州甲壳虫跨境网络服务 焊管生产线_焊管机组_轧辊模具_焊管设备_焊管设备厂家_石家庄翔昱机械 | 精密线材测试仪-电线电缆检测仪-苏州欣硕电子科技有限公司 | 执业药师报名时间,报考条件,考试时间-首页入口| 云杂志网-学术期刊-首页| 中高频感应加热设备|高频淬火设备|超音频感应加热电源|不锈钢管光亮退火机|真空管烤消设备 - 郑州蓝硕工业炉设备有限公司 | 工业硝酸钠,硝酸钠厂家-淄博「文海工贸」 | 橡胶接头|可曲挠橡胶接头|橡胶软接头安装使用教程-上海松夏官方网站 | 东莞市踏板石餐饮管理有限公司_正宗桂林米粉_正宗桂林米粉加盟_桂林米粉加盟费-东莞市棒子桂林米粉 | 东莞办公家具厂家直销-美鑫【免费3D效果图】全国办公桌/会议桌定制 | 成都亚克力制品,PVC板,双色板雕刻加工,亚克力门牌,亚克力标牌,水晶字雕刻制作-零贰捌广告 | 儋州在线-儋州招聘找工作、找房子、找对象,儋州综合生活信息门户! | 粉末冶金注射成型厂家|MIM厂家|粉末冶金齿轮|MIM零件-深圳市新泰兴精密科技 |