欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解APScheduler如何設置任務不并發(fā)

 更新時間:2022年07月19日 11:39:34   作者:Jayce~  
本文主要介紹了APScheduler如何設置任務不并發(fā),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

1.軟件環(huán)境

Windows10 教育版64位
Python 3.6.3
APScheduler 3.6.3

2.問題描述

Python中定時任務的解決方案,總體來說有四種,分別是:crontab、 scheduler、 Celery、APScheduler,其中:

  • crontab是 Linux 的一個定時任務管理工具,在Windows上面有替代品pycron,但Windows不像 Linux那樣有很多強大的命令程序,pycron使用起來有局限性,定制性不好;
  • Scheduler太過于簡單、復雜一點的定時任務做起來太困難,特別是以月份以上時間單位的定時任務;
  • Celery依賴的軟件比較多,比較耗資源;
  • APScheduler(Advanced Python Scheduler) 基于 Quartz,可以跨平臺而且配置方便,提供了date、interval、cron3種不同的觸發(fā)器,與Linux上原生的 crontab 格式兼容,可以設置任何高度復雜的定時任務,靈活的要死。

在此不介紹APScheduler的基本特性,有需要的可以直接去看APScheduler官方文檔,我們直接切到主題:

APScheduler如何設置任務不并發(fā)(即第一個任務執(zhí)行完再執(zhí)行下一個)?

APScheduler在多個任務相同時間點同時被觸發(fā)時,會同時并發(fā)執(zhí)行多個任務,如使用下方的示例代碼:

'''
===========================================
  @author:  jayce
  @file:    apscheduler設置任務不并發(fā).py         
  @time:    2022/7/1/001   19:38 
===========================================
'''
from apscheduler.schedulers.blocking import BlockingScheduler
import time


def job_printer(text):
    '''
    死循環(huán),用來模擬長時間執(zhí)行的任務
    :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秒執(zhí)行一次!'])
    schedule.add_job(job_printer, "cron", second='*/20', args=['每20秒執(zhí)行一次!'])
 
    schedule.print_jobs()
    schedule.start()

可以看到,函數(shù)job_printer是一個死循環(huán),用來模擬長時間執(zhí)行的任務,我們使用add_jobAPScheduler中添加2個job_printer,區(qū)別是2個任務的時間間隔為:每10秒執(zhí)行一次每20秒執(zhí)行一次。
因為job_printer是一個死循環(huán),相當于job_printer一直沒有被執(zhí)行完,但其實APScheduler在任務沒有被執(zhí)行完的情況下,同時執(zhí)行多個不同的job_printer

job text:每10秒執(zhí)行一次!
job text:每20秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每20秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每20秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每20秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
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交替被執(zhí)行,而其實10秒的job_printer其實根本沒有執(zhí)行完。這在CPU或者GPU等硬件設備能夠承擔負載的情況下,當然是好事,但如果你的硬件不夠的話,發(fā)生OOM等資源不夠的情況,程序就被中斷了,導致你的模型訓練或業(yè)務邏輯失敗!
具體的
我這邊是使用APSchedulerTensorflow進行在線學習(online learning)時,在不同的時間節(jié)點下會對模型使用不一樣的重訓練方式,如有2個定時任務(A:每10秒執(zhí)行一次,B:每20秒執(zhí)行一次)和2種重訓練方式(XY),當你的顯存存在如下情況:

顯存很少只夠一個程序進行訓練,不能多個程序同時運行,否則會OOM;

那么只能引導程序依次執(zhí)行,而不能并發(fā)執(zhí)行,等當同一時間內(nèi)XY同時被觸發(fā)時,只執(zhí)行其中1個,另外1個不執(zhí)行。

那這個時候又該怎么辦呢

3.解決方法

通過查閱官方文檔,發(fā)現(xiàn)可以通過設置執(zhí)行任務的線程數(shù),來控制只有1個執(zhí)行器進行任務的執(zhí)行,進而達到執(zhí)行完任務X再執(zhí)行任務Y,具體如下:

'''
===========================================
  @author:  jayce
  @file:    apscheduler設置任務不并發(fā).py         
  @time:    2022/7/1/001   19:38 
===========================================
'''
from apscheduler.executors.pool import ThreadPoolExecutor


if __name__ == '__main__':
    # 為了防止全量和增量并發(fā)造成顯存溢出,進而訓練失敗,設置同一時間只能有一個任務運行
    schedule = BlockingScheduler(executors={'default': ThreadPoolExecutor(1)})

通過向BlockingScheduler設定最大的ThreadPoolExecutor=1,即可達到我們想要的效果!

4.結果預覽

job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
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秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
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)

即:

在這里插入圖片描述

可以看到,一直在執(zhí)行第1個被觸發(fā)的任務,相同時間被觸發(fā)的任務都被skipped了~~
當然,如果你想要第1個任務執(zhí)行完時,執(zhí)行被跳過的任務,可以通過在add_job中設置misfire_grace_time實現(xiàn)!

FAQ

1.APScheduler如果某個任務掛掉了,整個定時任務程序會中斷嗎?還是下次時間繼續(xù)執(zhí)行該任務?

答案是:程序不會中斷,到下次執(zhí)行任務的時間點,還會重新執(zhí)行。
具體的,使用如下測試代碼:

'''
===========================================
  @author:  jayce
  @file:    apscheduler設置任務不并發(fā).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():
    '''
    異常制造器,用來模擬任務執(zhí)行被中斷
    :return:
    '''
    return 1 / 0


def job_printer(text):
    '''
    死循環(huán),用來模擬長時間執(zhí)行的任務
    :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秒執(zhí)行一次!'])
    schedule.add_job(exception_maker, "cron", second='*/5')

    schedule.print_jobs()
    schedule.start()

可以看到exception_maker已經(jīng)失敗多次,但是不影響其他任務和它自身的下次執(zhí)行:

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:\Users\Jayce\Anaconda3\envs\tf2.3\lib\site-packages\apscheduler\executors\base.py", line 125, in run_job
    retval = job.func(*job.args, **job.kwargs)
  File "E:/Code/Python/demo代碼/apscheduler設置任務不并發(fā).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:\Users\Jayce\Anaconda3\envs\tf2.3\lib\site-packages\apscheduler\executors\base.py", line 125, in run_job
    retval = job.func(*job.args, **job.kwargs)
  File "E:/Code/Python/demo代碼/apscheduler設置任務不并發(fā).py", line 14, in exception_maker
    return 1 / 0
ZeroDivisionError: division by zero
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
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:\Users\Jayce\Anaconda3\envs\tf2.3\lib\site-packages\apscheduler\executors\base.py", line 125, in run_job
    retval = job.func(*job.args, **job.kwargs)
  File "E:/Code/Python/demo代碼/apscheduler設置任務不并發(fā).py", line 14, in exception_maker
    return 1 / 0
ZeroDivisionError: division by zero
job text:每10秒執(zhí)行一次!
job text:每10秒執(zhí)行一次!
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:\Users\Jayce\Anaconda3\envs\tf2.3\lib\site-packages\apscheduler\executors\base.py", line 125, in run_job
    retval = job.func(*job.args, **job.kwargs)
  File "E:/Code/Python/demo代碼/apscheduler設置任務不并發(fā).py", line 14, in exception_maker
    return 1 / 0
ZeroDivisionError: division by zero
job text:每10秒執(zhí)行一次!

即:

在這里插入圖片描述

到此這篇關于詳解APScheduler如何設置任務不并發(fā)的文章就介紹到這了,更多相關APScheduler 任務不并發(fā)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解如何使用Python操作MySQL的各種功能

    詳解如何使用Python操作MySQL的各種功能

    當今互聯(lián)網(wǎng)時代,數(shù)據(jù)處理已經(jīng)成為了一個非常重要的任務。MySQL作為一款開源的關系型數(shù)據(jù)庫,被廣泛應用于各種場景。本文將介紹如何使用Python操作MySQL的各種功能,以及一些高級用法,希望對大家有所幫助
    2023-04-04
  • pandas如何將datetime64[ns]轉(zhuǎn)為字符串日期

    pandas如何將datetime64[ns]轉(zhuǎn)為字符串日期

    這篇文章主要介紹了pandas如何將datetime64[ns]轉(zhuǎn)為字符串日期,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • python開發(fā)之IDEL(Python GUI)的使用方法圖文詳解

    python開發(fā)之IDEL(Python GUI)的使用方法圖文詳解

    這篇文章主要介紹了python開發(fā)之IDEL(Python GUI)的使用方法,結合圖文形式較為詳細的分析總結了Python GUI的具體使用方法,需要的朋友可以參考下
    2015-11-11
  • python 自定義異常和主動拋出異常(raise)的操作

    python 自定義異常和主動拋出異常(raise)的操作

    這篇文章主要介紹了python 自定義異常和主動拋出異常(raise)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • python中opencv實現(xiàn)圖片文本傾斜校正

    python中opencv實現(xiàn)圖片文本傾斜校正

    圖片有的時候需要矯正,本文主要介紹了python中opencv實現(xiàn)圖片文本傾斜校正,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Python 隨機按鍵模擬2小時

    Python 隨機按鍵模擬2小時

    這篇文章主要介紹了Python 隨機按鍵模擬的方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-12-12
  • Python pip install之SSL異常處理操作

    Python pip install之SSL異常處理操作

    這篇文章主要介紹了Python pip install之SSL異常處理操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • python3.7.3版本和django2.2.3版本是否可以兼容

    python3.7.3版本和django2.2.3版本是否可以兼容

    在本篇文章里小編給大家整理的是一篇關于python3.7.3版本和django2.2.3版本是否可以兼容的相關知識點內(nèi)容,有興趣的朋友們可以學習下。
    2020-09-09
  • 詳解python tkinter 圖片插入問題

    詳解python tkinter 圖片插入問題

    這篇文章主要介紹了詳解python tkinter 圖片插入問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • python3.x 將byte轉(zhuǎn)成字符串的方法

    python3.x 將byte轉(zhuǎn)成字符串的方法

    今天小編就為大家分享一篇python3.x 將byte轉(zhuǎn)成字符串的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07

最新評論