亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何通過celery_one避免Celery定時任務重復執行的問題

發布時間:2021-11-01 09:10:38 來源:億速云 閱讀:282 作者:小新 欄目:開發技術

這篇文章主要介紹了如何通過celery_one避免Celery定時任務重復執行的問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

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

參考:https://blog.csdn.net/qq_41333582/article/details/83899884

有人使用 Redis 實現了分布式鎖,然后也有人使用了 Celery Once。

Celery Once 也是利用 Redis 加鎖來實現, Celery Once 在 Task 類基礎上實現了 QueueOnce 類,該類提供了任務去重的功能,所以在使用時,我們自己實現的方法需要將 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任務排隊,防止多次執行

安裝

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鍵)。否則,任務將正常運行。一旦任務完成(或由于異常而結束),鎖將被清除。如果在任務完成之前嘗試再次運行該任務,將會引發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,而不是引發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!"

感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何通過celery_one避免Celery定時任務重復執行的問題”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁明县| 罗城| 泸水县| 准格尔旗| 光山县| 泾阳县| 阿拉善左旗| 江西省| 霍林郭勒市| 河津市| 承德县| 琼结县| 淮北市| 阿拉尔市| 英山县| 内丘县| 增城市| 贵南县| 曲沃县| 漠河县| 武城县| 泸水县| 吴旗县| 普兰县| 门头沟区| 平顺县| 荔波县| 白水县| 仪陇县| 遂溪县| 嘉祥县| 济南市| 昔阳县| 泸州市| 漯河市| 呼图壁县| 田阳县| 忻城县| 寻甸| 贵阳市| 西青区|