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

聊聊通過celery_one避免Celery定時任務重復執(zhí)行的問題

 更新時間:2021年10月31日 10:44:36   作者:吾星喵  
Celery Once 也是利用 Redis 加鎖來實現(xiàn), Celery Once 在 Task 類基礎上實現(xiàn)了 QueueOnce 類,該類提供了任務去重的功能,今天通過本文給大家介紹通過celery_one避免Celery定時任務重復執(zhí)行的問題,感興趣的朋友一起看看吧

在使用Celery統(tǒng)計每日訪問數量的時候,發(fā)現(xiàn)一個任務會同時執(zhí)行兩次,發(fā)現(xiàn)同一時間內(1s內)竟然同時發(fā)送了兩次任務,也就是同時產生了兩個worker,造成統(tǒng)計兩次,一直找不到原因。

參考:http://www.dbjr.com.cn/article/226849.htm

有人使用 Redis 實現(xiàn)了分布式鎖,然后也有人使用了 Celery Once。

Celery Once 也是利用 Redis 加鎖來實現(xiàn), Celery Once 在 Task 類基礎上實現(xiàn)了 QueueOnce 類,該類提供了任務去重的功能,所以在使用時,我們自己實現(xiàn)的方法需要將 QueueOnce 設置為 base

@task(base=QueueOnce, once={'graceful': True})

后面的 once 參數表示,在遇到重復方法時的處理方式,默認 graceful 為 False,那樣 Celery 會拋出 AlreadyQueued 異常,手動設置為 True,則靜默處理。

另外如果要手動設置任務的 key,可以指定 keys 參數

@celery.task(base=QueueOnce, once={'keys': ['a']})
def slow_add(a, b):
    sleep(30)
    return a + b

解決步驟

Celery One允許你將Celery任務排隊,防止多次執(zhí)行

安裝

pip install -U celery_once

要求,需要Celery4.0,老版本可能運行,但不是官方支持的。

使用celery_once,tasks需要繼承一個名為QueueOnce的抽象base tasks

Once安裝完成后,需要配置一些關于ONCE的選項在Celery配置中

from celery import Celery
from celery_once import QueueOnce
from time import sleep

celery = Celery('tasks', broker='amqp://guest@localhost//')

# 一般之前的配置沒有這個,需要添加上
celery.conf.ONCE = {
  'backend': 'celery_once.backends.Redis',
  'settings': {
    'url': 'redis://localhost:6379/0',
    'default_timeout': 60 * 60
  }
}

# 在原本沒有參數的里面加上base
@celery.task(base=QueueOnce)
def slow_task():
    sleep(30)
    return "Done!"

要確定配置,需要取決于使用哪個backend進行鎖定,查看Backends

在后端,這將覆蓋apply_async和delay。它不影響直接調用任務。

在運行任務時,celery_once檢查是否沒有鎖定(針對Redis鍵)。否則,任務將正常運行。一旦任務完成(或由于異常而結束),鎖將被清除。如果在任務完成之前嘗試再次運行該任務,將會引發(fā)AlreadyQueued異常。

example.delay(10)
example.delay(10)
Traceback (most recent call last):
    ..
AlreadyQueued()
result = example.apply_async(args=(10))
result = example.apply_async(args=(10))
Traceback (most recent call last):
    ..
AlreadyQueued()

graceful:如果在任務的選項中設置了once={'graceful': True},或者在運行時設置了apply_async,則任務可以返回None,而不是引發(fā)AlreadyQueued異常。

from celery_once import AlreadyQueued
# Either catch the exception,
try:
    example.delay(10)
except AlreadyQueued:
    pass
# Or, handle it gracefully at run time.
result = example.apply(args=(10), once={'graceful': True})
# or by default.
@celery.task(base=QueueOnce, once={'graceful': True})
def slow_task():
    sleep(30)
    return "Done!"

其他功能請訪問:https://pypi.org/project/celery_once/

到此這篇關于通過celery_one避免Celery定時任務重復執(zhí)行的文章就介紹到這了,更多相關Celery定時任務重復執(zhí)行內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Python爬蟲爬取微信朋友圈

    Python爬蟲爬取微信朋友圈

    這篇文章主要介紹了Python爬蟲爬取微信朋友圈的方法,文中講解非常細致,幫助大家更好的理解和學習Python爬蟲,感興趣的朋友可以了解下
    2020-08-08
  • python概率計算器實例分析

    python概率計算器實例分析

    這篇文章主要介紹了python概率計算器實現(xiàn)方法,實例分析了Python實現(xiàn)概率計算的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • pycharm配置python 設置pip安裝源為豆瓣源

    pycharm配置python 設置pip安裝源為豆瓣源

    這篇文章主要介紹了pycharm配置python 設置pip安裝源為豆瓣源,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • 深入理解Python單元測試unittest的使用示例

    深入理解Python單元測試unittest的使用示例

    本篇文章主要介紹了深入理解Python單元測試unittest的使用示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 基于Python實現(xiàn)交互式文件瀏覽器

    基于Python實現(xiàn)交互式文件瀏覽器

    這篇文章主要為大家詳細介紹了如何基于Python實現(xiàn)簡單的交互式文件瀏覽器,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-04-04
  • Python Dask庫處理大規(guī)模數據集的強大功能實戰(zhàn)

    Python Dask庫處理大規(guī)模數據集的強大功能實戰(zhàn)

    Dask是一個靈活、開源的Python庫,專為處理大規(guī)模數據集而設計,與傳統(tǒng)的單機計算相比,Dask能夠在分布式系統(tǒng)上運行,有效利用集群的計算資源,本文將深入介紹Dask的核心概念、功能和實際應用,通過豐富的示例代碼展示其在大數據處理領域的強大能力
    2023-12-12
  • python腳本內運行l(wèi)inux命令的方法

    python腳本內運行l(wèi)inux命令的方法

    這篇文章主要介紹了python腳本內運行l(wèi)inux命令的方法,實例分析了Python基于subprocess模塊操作Linux命令的相關技巧,需要的朋友可以參考下
    2015-07-07
  • Django中Model的使用方法教程

    Django中Model的使用方法教程

    最近學習了一下Django文檔的model部分,通過學習的內容整理了這篇文章,下面這篇文章主要給大家介紹了關于Django中Model的使用方法的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。
    2018-03-03
  • 安裝2019Pycharm最新版本的教程詳解

    安裝2019Pycharm最新版本的教程詳解

    這篇文章主要介紹了安裝2019Pycharm最新版本的教程詳解,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • Python time模塊詳解(常用函數實例講解,非常好)

    Python time模塊詳解(常用函數實例講解,非常好)

    在平常的代碼中,我們常常需要與時間打交道。在Python中,與時間處理有關的模塊就包括:time,datetime以及calendar。這篇文章,主要講解time模塊。
    2014-04-04

最新評論