博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用celery实现订单超时取消
阅读量:3961 次
发布时间:2019-05-24

本文共 2952 字,大约阅读时间需要 9 分钟。

项目目录结构

我们需要新增一个任务目录,例如order:

celey_tasks/	    ├── config.py	    ├── __init__.py	    ├── main.py	    ├── order/	           ├── __init__.py	          └── tasks.py

在main.py中,注册任务目录【注意,接下来后面我们使用django的模型处理,所以必须对django的配置进行引入】

import osfrom celery import Celery# 1. 创建示例对象app = Celery("luffy")# 2. 加载配置app.config_from_object("celery_tasks.config")# 3. 注册任务[自动搜索并加载任务]# 参数必须必须是一个列表,里面的每一个任务都是任务的路径名称# app.autodiscover_tasks(["任务1","任务2"])app.autodiscover_tasks(["celery_tasks.order"])# 4. 在终端下面运行celery命令启动celery# celery -A 主程序 worker --loglevel=info# celery -A celery_tasks.main worker --loglevel=info

接下来,在order任务目录下, 创建固定名字的任务文件tasks.py,代码:

from celery_tasks.main import app@app.task(name="check_order")def check_order():    print("检查订单是否过期!!!")

接下来,我们需要把这个任务设置定时任务,所以需要借助Celery本身提供的Crontab模块。

在配置文件中,对定时任务进行注册:

# 任务队列的链接地址broker_url = 'redis://127.0.0.1:6379/15'# 结果队列的链接地址result_backend = 'redis://127.0.0.1:6379/14'from celery.schedules import crontabfrom .main import app# 定时任务的调度列表,用于注册定时任务app.conf.beat_schedule = {
# Executes every Monday morning at 7:30 a.m. 'check_order_outtime': {
# 本次调度的任务 'task': 'check_order', # 这里的任务名称必须先到main.py中注册 # 定时任务的调度周期 # 'schedule': crontab(minute=0, hour=0), # 每周凌晨00:00 'schedule': crontab(), # 每分钟 # 'args': (16, 16), # 注意:任务就是一个函数,所以如果有参数则需要传递 },}

接下来,我们就可以重启Celery并启用Celery的定时任务调度器

先在终端下,运行celery的定时任务程序,以下命令:

celery -A celery_tasks.main beat  # ycelery.main 是celery的主应用文件

然后再新建一个终端,运行以下命令,上面的命令必须先指定:

celery -A celery_tasks.main worker --loglevel=info

定时任务

经过上面的测试以后,我们接下来只需改造上面的任务函数,用于判断修改订单是否超时。

要完成订单的任务功能,如果需要调用django框架的模型操作,那么必须针对django框架进行配置加载和初始化。

main.py,代码

import osfrom celery import Celery# 1. 创建示例对象app = Celery("luffy")# 把celery和django进行组合,识别和加载django的配置文件os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffyapi.settings.dev')# 在当前clery中启动django框架,对django框架进行进行初始化import djangodjango.setup()# 2. 加载配置app.config_from_object("celery_tasks.config")# 3. 注册任务[自动搜索并加载任务]# 参数必须必须是一个列表,里面的每一个任务都是任务的路径名称# app.autodiscover_tasks(["任务1","任务2"])app.autodiscover_tasks(["celery_tasks.sms","celery_tasks.order"])# 4. 在终端下面运行celery命令启动celery# celery -A 主程序 worker --loglevel=info# celery -A celery_tasks.main worker --loglevel=info

注意,因为在django中是有时区配置的,所以,我们在django框架配置中也要修改时区配置。

任务代码tasks.py的实现:

from celery_tasks.main import appfrom orders.models import Orderfrom datetime import datetimefrom django.conf import settings@app.task(name="check_order")def check_order():    # 查询出所有已经超时的订单    # 超时条件: 当前时间 > (订单生成时间 + 超时时间)   =====>>>>  (当前时间 - 超时时间) > 订单生成时间    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,代码:

# 设置订单超时超时的时间[单位: 秒]ORDER_TIMEOUT = 12 * 60 * 60

转载地址:http://awhzi.baihongyu.com/

你可能感兴趣的文章