Django中如何使用Celery執(zhí)行異步任務(wù)
更新時間:2023年11月24日 09:13:12 作者:G_scsd
這篇文章主要介紹了Django中如何使用Celery執(zhí)行異步任務(wù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
DJango使用Celery異步任務(wù)
1. 安裝
pip install celery==4.4.7
2. 配置
2.1 setting.py
CELERY_BROKER_URL = 'redis://127.0.0.1:6379/1' CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/1' CELERY_RESULT_SERIALIZER = 'json'
2.2 setting同級目錄
- 2.2.1新建celery.py
from __future__ import absolute_import, unicode_literals
import os
from celery import Celery
from django.conf import settings
# set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'DjangoFunction.settings')
app = Celery('test_celery') # 定義全局的Celery任務(wù) test_celery 隨便寫
# Using a string here means the worker doesn't have to serialize
# the configuration object to child processes.
# - namespace='CELERY' means all celery-related configuration keys
# should have a `CELERY_` prefix.
app.config_from_object('django.conf:settings', namespace='CELERY') # 固定配置
# Load task modules from all registered Django app configs.
app.autodiscover_tasks(['CeleryFunc']) # 把需要用定時任務(wù)的APP加進(jìn)去
@app.task(bind=True)
def debug_task(self):
print('Request: {0!r}'.format(self.request))
- 2.2.2 init.py
from __future__ import absolute_import, unicode_literals from .celery import app as celery_app # 重命名 __all__ = ['celery_app'] # 把重命名的APP寫進(jìn)去
3. Django APP 中新建tasks.py文件
import time
from loguru import logger
# Django環(huán)境的初始化
# 在任務(wù)處理者一段加這幾句
import os
import django
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'DjangoFunction.settings')
django.setup()
from DjangoFunction import celery_app
# bind=True, 加了這個就必須加 self, 這個能打印定時任務(wù)的信息(這兩個都可以不加)
@celery_app.task(bind=True)
def my_asynch_task(self):
"""
我的 異步 任務(wù)
:return:
"""
logger.info('開始執(zhí)行異步任務(wù)')
time.sleep(3)
print('------', self.request.id)
logger.info('結(jié)束執(zhí)行異步任務(wù)')
return 10
4. views.py文件
from rest_framework.views import APIView
from rest_framework.response import Response
from CeleryFunc.tasks import my_asynch_task
import time
class AsyncAPIView(APIView):
"""
數(shù)據(jù)集
"""
def get(self, request, format=None):
try:
start_time = time.time()
# 這兩種方法都可以,不加后面這個方法就不是異步了
# result = my_asynch_task.apply_async()
result = my_asynch_task.delay()
print(dir(result))
print('result.state = ', result.state)
print('result.status = ', result.status)
print('result.successful = ', result.successful)
print('result.result = ', result.result)
print('result.name = ', result.name)
resp = {
'code': 200,
'message': 'success',
}
end_date = time.time()
print('耗時: ', end_date - start_time)
except Exception as e:
resp = {
'code': 300,
'message': str(e),
}
return Response(resp)
后臺可以啟動這個命令來查看異步任務(wù)是否加入和日志
DjangoFunction是項目名稱
celery worker -A DjangoFunction -l info -P eventlet
項目結(jié)構(gòu)

總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
python格式化輸出保留2位小數(shù)的實現(xiàn)方法
這篇文章主要介紹了python格式化輸出保留2位小數(shù)的實現(xiàn)方法,需要的朋友可以參考下2019-07-07
django 自定義filter 判斷if var in list的例子
今天小編就為大家分享一篇django 自定義filter 判斷if var in list的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08
如何將自己的python代碼發(fā)布在pip install給別人使用你知道嗎
這篇文章主要介紹了python如何發(fā)布自已的pip項目,方便大家學(xué)習(xí),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2021-08-08
正確理解Python中if __name__ == ''__main__''
今天小編就為大家分享一篇關(guān)于正確理解Python中if __name__ == '__main__' ,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01

