Django 中使用Celery实现异步任务

1、在settings.py 同级目录下,新增一个celery.py的文件

需要注意的是:你的项目目录名要和配置一样
例如我的项目目录名就是 base_django_api
我的目录结构如下:
在这里插入图片描述

# celery.py
from __future__ import absolute_import, unicode_literals
import os
from celery import Celery, platforms
from django.conf import settings


os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'base_django_api.settings')
app = Celery('base_django_api')

app.config_from_object('django.conf:settings')

app.autodiscover_tasks()

platforms.C_FORCE_ROOT = True

@app.task(bind=True)
def debug_task(self):
    print('Request: {0!r}'.format(self.request))

2、修改settings.py 同级目录下的 __init__.py文件

加入一下内容

from __future__ import absolute_import, unicode_literals

# This will make sure the app is always imported when
# Django starts so that shared_task will use this app.
from .celery import app as celery_app

__all__ = ('celery_app',)

3、在你的app里面创建tasks.py文件

例如:本例在 base app内创建一个tasks.py文件

from __future__ import absolute_import, unicode_literals
from celery import shared_task
from base_django_api.celery import app
import time

@shared_task
def mul(x, y):
    print('发生耗时操作...')
    time.sleep(10) # 模拟耗时操作
    return x * y

4、使用视图函数注册到路由,通过http请求来出发异步任务

本例:用来模拟实际场景中的异步请求,在收到http请求时,发起异步任务去执行,http调用处直接马上返回结果,优化用户体验。
修改对应的视图函数views.py

# apps/base/views.py
from .tasks import mul
class BeginCelery(APIView):

    def get(self, request):
        '''
        测试开启celery
        '''
        try:
            json_data = {"message": "ok", "errorCode": 0, "data": {}}
            #发起异步任务 
            mul_result = mul.delay(3,5)
            return Response(json_data)
        except Exception as e:
            print('发生错误:',e)
            return Response({"message": "出现了无法预料的view视图错误:%s" % e, "errorCode": 1, "data": {}})

注册到路由urls.py

from base.views import BeginCelery
from django.urls import path, include

urlpatterns = [
    path('celery/', BeginCelery.as_view(), name='celery测试'),
]

启动Django:

python manage.py runserver

启动celery:

celery -A base_django_api worker -l info

调用接口测试
在这里插入图片描述
查看celery运行结果
在这里插入图片描述

5、为什么本例不要Celery实现定时任务

因为在Django中,使用django_crontab 实现定时任务,更加的简洁、方便,感兴趣的同学可以查一下。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章