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

基于多進(jìn)程中APScheduler重復(fù)運(yùn)行的解決方法

 更新時(shí)間:2019年07月22日 08:40:23   作者:猛禽  
今天小編就為大家分享一篇基于多進(jìn)程中APScheduler重復(fù)運(yùn)行的解決方法,具有很好的價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

問(wèn)題

在一個(gè)python web應(yīng)用中需要定時(shí)執(zhí)行一些任務(wù),所以用了APScheduler這個(gè)庫(kù)。又因?yàn)槭怯胒lask這個(gè)web框架,所以用了flask-apscheduler這個(gè)插件(本質(zhì)上與直接用APScheduler一樣,這里不作區(qū)分)。

在開發(fā)中直接測(cè)試運(yùn)行是沒有問(wèn)題的,但是用gunicorn部署以后發(fā)生了重復(fù)運(yùn)行的問(wèn)題:

每個(gè)任務(wù)在時(shí)間到的時(shí)刻會(huì)同時(shí)執(zhí)行好幾遍。

注意了一下重復(fù)的數(shù)量,恰恰是gunicorn里配置的worker進(jìn)程數(shù)量,顯然是每個(gè)worker進(jìn)程都啟動(dòng)了一份scheduler造成。

解決

可以想到的方案有幾個(gè):

用--preload啟動(dòng)gunicorn,確保scheduler只在loader的時(shí)候創(chuàng)建一次

另外創(chuàng)建一個(gè)單獨(dú)的定時(shí)任務(wù)項(xiàng)目,單獨(dú)以一個(gè)進(jìn)程運(yùn)行

用全局鎖確保scheduler只運(yùn)行一次

經(jīng)過(guò)實(shí)踐,只有第三個(gè)方案比較好。

preload的問(wèn)題:

雖然這樣可以使用scheduler創(chuàng)建代碼只執(zhí)行一次,但是問(wèn)題也在于它只執(zhí)行一次,重新部署以后如果用kill -HUP重啟gunicorn,它并不會(huì)重啟,甚至整個(gè)項(xiàng)目都不會(huì)更新。這是preload的副作用,除非重寫部署腳本,完全重啟應(yīng)用。

單獨(dú)進(jìn)程的問(wèn)題:

也是因?yàn)椴渴鹇闊枰嘁惶撞渴鸱桨福m然用Docker會(huì)比較方便,但仍然不喜歡,而且同時(shí)維護(hù)兩個(gè)項(xiàng)目也多出很多不必要的事情。

全局鎖是一個(gè)較好的方案,但問(wèn)題在于找一個(gè)合適的鎖。

python自帶的多進(jìn)程多線程鎖方案都需要一個(gè)共享變量來(lái)維護(hù),但是因?yàn)閣orker進(jìn)程是被gunicorn的主進(jìn)程啟動(dòng)的,并不方便自己維護(hù),所以需要一個(gè)系統(tǒng)級(jí)的鎖。

在Stackoverflow上看到有人是用了一個(gè)socket端口來(lái)做鎖實(shí)現(xiàn)這個(gè)方案,但是我也不喜歡這樣浪費(fèi)一個(gè)寶貴的端口資源。不過(guò)這倒給了我一個(gè)啟發(fā):

可以用文件鎖!

于是有了這個(gè)解決方案:

import atexit
import fcntl
from flask_apscheduler import APScheduler

def init(app):
 f = open("scheduler.lock", "wb")
 try:
  fcntl.flock(f, fcntl.LOCK_EX | fcntl.LOCK_NB)
  scheduler = APScheduler()
  scheduler.init_app(app)
  scheduler.start()
 except:
  pass
 def unlock():
  fcntl.flock(f, fcntl.LOCK_UN)
  f.close()
 atexit.register(unlock)

原理

init函數(shù)為flask項(xiàng)目初始化所調(diào)用,這里為scheduler模塊的初始化部分。

首先打開(或創(chuàng)建)一個(gè)scheduler.lock文件,并加上非阻塞互斥鎖。成功后創(chuàng)建scheduler并啟動(dòng)。

如果加文件鎖失敗,說(shuō)明scheduler已經(jīng)創(chuàng)建,就略過(guò)創(chuàng)建scheduler的部分。

最后注冊(cè)一個(gè)退出事件,如果這個(gè)flask項(xiàng)目退出,則解鎖并關(guān)閉scheduler.lock文件的鎖。

以上這篇基于多進(jìn)程中APScheduler重復(fù)運(yùn)行的解決方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python學(xué)習(xí) 流程控制語(yǔ)句詳解

    python學(xué)習(xí) 流程控制語(yǔ)句詳解

    下面小編就為大家?guī)?lái)一篇python學(xué)習(xí) 流程控制語(yǔ)句詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-06-06
  • keras中的backend.clip用法

    keras中的backend.clip用法

    這篇文章主要介紹了keras中的backend.clip用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05
  • python實(shí)現(xiàn)Zabbix-API監(jiān)控

    python實(shí)現(xiàn)Zabbix-API監(jiān)控

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)Zabbix-API監(jiān)控,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • 一文搞懂Python中的進(jìn)程,線程和協(xié)程

    一文搞懂Python中的進(jìn)程,線程和協(xié)程

    并發(fā)編程是實(shí)現(xiàn)多任務(wù)協(xié)同處理,改善系統(tǒng)性能的方式。Python中實(shí)現(xiàn)并發(fā)編程主要依靠進(jìn)程、線程和協(xié)程,本文將通過(guò)示例詳解三者的區(qū)別,感興趣的可以了解一下
    2022-05-05
  • Python多模塊引用由此引發(fā)的相對(duì)路徑混亂問(wèn)題

    Python多模塊引用由此引發(fā)的相對(duì)路徑混亂問(wèn)題

    這篇文章主要介紹了Python多模塊引用由此引發(fā)的相對(duì)路徑混亂問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • python實(shí)現(xiàn)小世界網(wǎng)絡(luò)生成

    python實(shí)現(xiàn)小世界網(wǎng)絡(luò)生成

    今天小編就為大家分享一篇python實(shí)現(xiàn)小世界網(wǎng)絡(luò)生成,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • 在Python程序員面試中被問(wèn)的最多的10道題

    在Python程序員面試中被問(wèn)的最多的10道題

    本篇文章我們?yōu)榇蠹艺砹嗽赑ython程序員面試中被問(wèn)的最多的10道題,我們還給出了最簡(jiǎn)便的解決辦法,一起學(xué)習(xí)下。
    2017-12-12
  • 在Python中實(shí)現(xiàn)字典反轉(zhuǎn)案例

    在Python中實(shí)現(xiàn)字典反轉(zhuǎn)案例

    這篇文章主要介紹了在Python中實(shí)現(xiàn)字典反轉(zhuǎn)案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • Python3交互式shell ipython3安裝及使用詳解

    Python3交互式shell ipython3安裝及使用詳解

    這篇文章主要介紹了Python3交互式shell ipython3安裝及使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • python中讀入二維csv格式的表格方法詳解(以元組/列表形式表示)

    python中讀入二維csv格式的表格方法詳解(以元組/列表形式表示)

    這篇文章主要介紹了python中如何讀入二維csv格式的表格(以元組/列表形式表示),本文通過(guò)兩種方法給大家詳細(xì)介紹,通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04

最新評(píng)論