本文實(shí)例為大家分享了celery實(shí)現(xiàn)訂單超時(shí)取消的具體代碼,供大家參考,具體內(nèi)容如下
Celery官方文檔中關(guān)于定時(shí)任務(wù)使用的說明
項(xiàng)目目錄結(jié)構(gòu)
我們需要新增一個(gè)任務(wù)目錄,例如order:
celey_tasks/
├── config.py
├── __init__.py
├── main.py
├── order/
├── __init__.py
└── tasks.py
在main.py中,注冊(cè)任務(wù)目錄【注意,接下來后面我們使用django的模型處理,所以必須對(duì)django的配置進(jìn)行引入】
import os
from celery import Celery
# 1. 創(chuàng)建示例對(duì)象
app = Celery("luffy")
# 2. 加載配置
app.config_from_object("celery_tasks.config")
# 3. 注冊(cè)任務(wù)[自動(dòng)搜索并加載任務(wù)]
# 參數(shù)必須必須是一個(gè)列表,里面的每一個(gè)任務(wù)都是任務(wù)的路徑名稱
# app.autodiscover_tasks(["任務(wù)1","任務(wù)2"])
app.autodiscover_tasks(["celery_tasks.order"])
# 4. 在終端下面運(yùn)行celery命令啟動(dòng)celery
# celery -A 主程序 worker --loglevel=info
# celery -A celery_tasks.main worker --loglevel=info
接下來,在order任務(wù)目錄下, 創(chuàng)建固定名字的任務(wù)文件tasks.py,代碼:
from celery_tasks.main import app
@app.task(name="check_order")
def check_order():
print("檢查訂單是否過期!!!")
接下來,我們需要把這個(gè)任務(wù)設(shè)置定時(shí)任務(wù),所以需要借助Celery本身提供的Crontab模塊。
在配置文件中,對(duì)定時(shí)任務(wù)進(jìn)行注冊(cè):
# 任務(wù)隊(duì)列的鏈接地址
broker_url = 'redis://127.0.0.1:6379/15'
# 結(jié)果隊(duì)列的鏈接地址
result_backend = 'redis://127.0.0.1:6379/14'
from celery.schedules import crontab
from .main import app
# 定時(shí)任務(wù)的調(diào)度列表,用于注冊(cè)定時(shí)任務(wù)
app.conf.beat_schedule = {
# Executes every Monday morning at 7:30 a.m.
'check_order_outtime': {
# 本次調(diào)度的任務(wù)
'task': 'check_order', # 這里的任務(wù)名稱必須先到main.py中注冊(cè)
# 定時(shí)任務(wù)的調(diào)度周期
# 'schedule': crontab(minute=0, hour=0), # 每周凌晨00:00
'schedule': crontab(), # 每分鐘
# 'args': (16, 16), # 注意:任務(wù)就是一個(gè)函數(shù),所以如果有參數(shù)則需要傳遞
},
}
接下來,我們就可以重啟Celery并啟用Celery的定時(shí)任務(wù)調(diào)度器
先在終端下,運(yùn)行celery的定時(shí)任務(wù)程序,以下命令:
celery -A celery_tasks.main beat # ycelery.main 是celery的主應(yīng)用文件
然后再新建一個(gè)終端,運(yùn)行以下命令,上面的命令必須先指定:
celery -A celery_tasks.main worker --loglevel=info
定時(shí)任務(wù)
經(jīng)過上面的測試以后,我們接下來只需改造上面的任務(wù)函數(shù),用于判斷修改訂單是否超時(shí)。
要完成訂單的任務(wù)功能,如果需要調(diào)用django框架的模型操作,那么必須針對(duì)django框架進(jìn)行配置加載和初始化。
main.py,代碼
import os
from celery import Celery
# 1. 創(chuàng)建示例對(duì)象
app = Celery("luffy")
# 把celery和django進(jìn)行組合,識(shí)別和加載django的配置文件
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffyapi.settings.dev')
# 在當(dāng)前clery中啟動(dòng)django框架,對(duì)django框架進(jìn)行進(jìn)行初始化
import django
django.setup()
# 2. 加載配置
app.config_from_object("celery_tasks.config")
# 3. 注冊(cè)任務(wù)[自動(dòng)搜索并加載任務(wù)]
# 參數(shù)必須必須是一個(gè)列表,里面的每一個(gè)任務(wù)都是任務(wù)的路徑名稱
# app.autodiscover_tasks(["任務(wù)1","任務(wù)2"])
app.autodiscover_tasks(["celery_tasks.sms","celery_tasks.order"])
# 4. 在終端下面運(yùn)行celery命令啟動(dòng)celery
# celery -A 主程序 worker --loglevel=info
# celery -A celery_tasks.main worker --loglevel=info
注意,因?yàn)樵赿jango中是有時(shí)區(qū)配置的,所以,我們?cè)赿jango框架配置中也要修改時(shí)區(qū)配置。
任務(wù)代碼tasks.py的實(shí)現(xiàn):
from celery_tasks.main import app
from orders.models import Order
from datetime import datetime
from django.conf import settings
@app.task(name="check_order")
def check_order():
# 查詢出所有已經(jīng)超時(shí)的訂單
# 超時(shí)條件: 當(dāng)前時(shí)間 > (訂單生成時(shí)間 + 超時(shí)時(shí)間) =====>>>> (當(dāng)前時(shí)間 - 超時(shí)時(shí)間) > 訂單生成時(shí)間
now = datetime.now().timestamp()
timeout_number = now - settings.ORDER_TIMEOUT
timeout = datetime.fromtimestamp(timeout_number)
timeout_order_list = Order.objects.filter(order_status=0, created_time__lte=timeout)
for order in timeout_order_list:
order.order_status = 3
order.save()
配置文件,settings/dev.py,代碼:
# 設(shè)置訂單超時(shí)超時(shí)的時(shí)間[單位: 秒]
ORDER_TIMEOUT = 12 * 60 * 60
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- python3中celery異步框架簡單使用+守護(hù)進(jìn)程方式啟動(dòng)
- Python Celery異步任務(wù)隊(duì)列使用方法解析
- python使用celery實(shí)現(xiàn)異步任務(wù)執(zhí)行的例子
- python celery分布式任務(wù)隊(duì)列的使用詳解
- Python環(huán)境下安裝使用異步任務(wù)隊(duì)列包Celery的基礎(chǔ)教程
- Python中celery的使用