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 实现定时任务,更加的简洁、方便,感兴趣的同学可以查一下。