<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
Windows10 教育版64位元
Python 3.6.3
APScheduler 3.6.3
Python
中定時任務的解決方案,總體來說有四種,分別是:crontab
、 scheduler
、 Celery
、APScheduler
,其中:
在此不介紹APScheduler
的基本特性,有需要的可以直接去看APScheduler官方檔案,我們直接切到主題:
APScheduler如何設定任務不併行(即第一個任務執行完再執行下一個)?
APScheduler
在多個任務相同時間點同時被觸發時,會同時並行執行多個任務,如使用下方的範例程式碼:
''' =========================================== @author: jayce @file: apscheduler設定任務不併行.py @time: 2022/7/1/001 19:38 =========================================== ''' from apscheduler.schedulers.blocking import BlockingScheduler import time def job_printer(text): ''' 死迴圈,用來模擬長時間執行的任務 :param text: :return: ''' while True: time.sleep(2) print("job text:{}".format(text)) if __name__ == '__main__': schedule = BlockingScheduler() schedule.add_job(job_printer, "cron", second='*/10', args=['每10秒執行一次!']) schedule.add_job(job_printer, "cron", second='*/20', args=['每20秒執行一次!']) schedule.print_jobs() schedule.start()
可以看到,函數job_printer
是一個死迴圈,用來模擬長時間執行的任務,我們使用add_job
向APScheduler
中新增2個job_printer
,區別是2個任務的時間間隔為:每10秒執行一次
和每20秒執行一次
。
因為job_printer
是一個死迴圈,相當於job_printer
一直沒有被執行完,但其實APScheduler
在任務沒有被執行完的情況下,同時執行多個不同的job_printer
:
job text:每10秒執行一次!
job text:每20秒執行一次!
job text:每10秒執行一次!
job text:每20秒執行一次!
job text:每10秒執行一次!
job text:每20秒執行一次!
job text:每10秒執行一次!
job text:每20秒執行一次!
job text:每10秒執行一次!
Execution of job "job_printer (trigger: cron[second='*/10'], next run at: 2022-07-01 20:47:50 CST)" skipped: maximum number of running instances reached (1)
即:
可以看到10秒的job_printer
和20秒的job_printer
交替被執行,而其實10秒的job_printer
其實根本沒有執行完。這在CPU
或者GPU
等硬體裝置能夠承擔負載的情況下,當然是好事,但如果你的硬體不夠的話,發生OOM等資源不夠的情況,程式就被中斷了,導致你的模型訓練或業務邏輯失敗!具體的
:
我這邊是使用APScheduler
和Tensorflow
進行線上學習(online learning
)時,在不同的時間節點下會對模型使用不一樣的重訓練方式,如有2個定時任務(A
:每10
秒執行一次,B
:每20
秒執行一次)和2種重訓練方式(X
和Y
),當你的視訊記憶體存在如下情況:
視訊記憶體很少只夠一個程式進行訓練,不能多個程式同時執行,否則會
OOM
;
那麼只能載入程式依次執行,而不能並行執行,等當同一時間內X
和Y
同時被觸發時,只執行其中1個,另外1個不執行。
那這個時候又該怎麼辦呢
通過查閱官方檔案,發現可以通過設定執行任務的執行緒數,來控制只有1個執行器進行任務的執行,進而達到執行完任務X
再執行任務Y
,具體如下:
''' =========================================== @author: jayce @file: apscheduler設定任務不併行.py @time: 2022/7/1/001 19:38 =========================================== ''' from apscheduler.executors.pool import ThreadPoolExecutor if __name__ == '__main__': # 為了防止全量和增量並行造成視訊記憶體溢位,進而訓練失敗,設定同一時間只能有一個任務執行 schedule = BlockingScheduler(executors={'default': ThreadPoolExecutor(1)})
通過向BlockingScheduler
設定最大的ThreadPoolExecutor=1
,即可達到我們想要的效果!
job text:每10秒執行一次!
job text:每10秒執行一次!
job text:每10秒執行一次!
job text:每10秒執行一次!
job text:每10秒執行一次!
Execution of job "job_printer (trigger: cron[second='*/10'], next run at: 2022-07-01 21:17:50 CST)" skipped: maximum number of running instances reached (1)
job text:每10秒執行一次!
job text:每10秒執行一次!
job text:每10秒執行一次!
job text:每10秒執行一次!
job text:每10秒執行一次!
Execution of job "job_printer (trigger: cron[second='*/10'], next run at: 2022-07-01 21:18:00 CST)" skipped: maximum number of running instances reached (1)
Execution of job "job_printer (trigger: cron[second='*/20'], next run at: 2022-07-01 21:18:00 CST)" skipped: maximum number of running instances reached (1)
即:
可以看到,一直在執行第1個被觸發的任務,相同時間被觸發的任務都被skipped
了~~
當然,如果你想要第1個任務執行完時,執行被跳過的任務,可以通過在add_job
中設定misfire_grace_time
實現!
1.APScheduler
如果某個任務掛掉了,整個定時任務程式會中斷嗎?還是下次時間繼續執行該任務?
答案是:程式不會中斷,到下次執行任務的時間點,還會重新執行。
具體的,使用如下測試程式碼:
''' =========================================== @author: jayce @file: apscheduler設定任務不併行.py @time: 2022/7/1/001 19:38 =========================================== ''' from apscheduler.schedulers.blocking import BlockingScheduler from apscheduler.executors.pool import ThreadPoolExecutor import time def exception_maker(): ''' 異常製造器,用來模擬任務執行被中斷 :return: ''' return 1 / 0 def job_printer(text): ''' 死迴圈,用來模擬長時間執行的任務 :param text: :return: ''' while True: time.sleep(2) print("job text:{}".format(text)) if __name__ == '__main__': schedule = BlockingScheduler() schedule.add_job(job_printer, "cron", second='*/10', args=['每10秒執行一次!']) schedule.add_job(exception_maker, "cron", second='*/5') schedule.print_jobs() schedule.start()
可以看到exception_maker
已經失敗多次,但是不影響其他任務和它自身的下次執行:
Job "exception_maker (trigger: cron[second='*/5'], next run at: 2022-07-01 19:53:30 CST)" raised an exception
Traceback (most recent call last):
File "C:UsersJayceAnaconda3envstf2.3libsite-packagesapschedulerexecutorsbase.py", line 125, in run_job
retval = job.func(*job.args, **job.kwargs)
File "E:/Code/Python/demo程式碼/apscheduler設定任務不併行.py", line 14, in exception_maker
return 1 / 0
ZeroDivisionError: division by zero
Job "exception_maker (trigger: cron[second='*/5'], next run at: 2022-07-01 19:53:35 CST)" raised an exception
Traceback (most recent call last):
File "C:UsersJayceAnaconda3envstf2.3libsite-packagesapschedulerexecutorsbase.py", line 125, in run_job
retval = job.func(*job.args, **job.kwargs)
File "E:/Code/Python/demo程式碼/apscheduler設定任務不併行.py", line 14, in exception_maker
return 1 / 0
ZeroDivisionError: division by zero
job text:每10秒執行一次!
job text:每10秒執行一次!
Job "exception_maker (trigger: cron[second='*/5'], next run at: 2022-07-01 19:53:40 CST)" raised an exception
Traceback (most recent call last):
File "C:UsersJayceAnaconda3envstf2.3libsite-packagesapschedulerexecutorsbase.py", line 125, in run_job
retval = job.func(*job.args, **job.kwargs)
File "E:/Code/Python/demo程式碼/apscheduler設定任務不併行.py", line 14, in exception_maker
return 1 / 0
ZeroDivisionError: division by zero
job text:每10秒執行一次!
job text:每10秒執行一次!
Execution of job "job_printer (trigger: cron[second='*/10'], next run at: 2022-07-01 19:53:40 CST)" skipped: maximum number of running instances reached (1)
Job "exception_maker (trigger: cron[second='*/5'], next run at: 2022-07-01 19:53:45 CST)" raised an exception
Traceback (most recent call last):
File "C:UsersJayceAnaconda3envstf2.3libsite-packagesapschedulerexecutorsbase.py", line 125, in run_job
retval = job.func(*job.args, **job.kwargs)
File "E:/Code/Python/demo程式碼/apscheduler設定任務不併行.py", line 14, in exception_maker
return 1 / 0
ZeroDivisionError: division by zero
job text:每10秒執行一次!
即:
到此這篇關於詳解APScheduler如何設定任務不併行的文章就介紹到這了,更多相關APScheduler 任務不併行內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45