Django中如何使用Celery執(zhí)行異步任務(wù)
更新時(shí)間:2023年11月24日 09:13:12 作者:G_scsd
這篇文章主要介紹了Django中如何使用Celery執(zhí)行異步任務(wù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
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同級(jí)目錄
- 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']) # 把需要用定時(shí)任務(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, 加了這個(gè)就必須加 self, 這個(gè)能打印定時(shí)任務(wù)的信息(這兩個(gè)都可以不加) @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() # 這兩種方法都可以,不加后面這個(gè)方法就不是異步了 # 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('耗時(shí): ', end_date - start_time) except Exception as e: resp = { 'code': 300, 'message': str(e), } return Response(resp)
后臺(tái)可以啟動(dòng)這個(gè)命令來查看異步任務(wù)是否加入和日志
DjangoFunction是項(xiàng)目名稱
celery worker -A DjangoFunction -l info -P eventlet
項(xiàng)目結(jié)構(gòu)
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python格式化輸出保留2位小數(shù)的實(shí)現(xiàn)方法
這篇文章主要介紹了python格式化輸出保留2位小數(shù)的實(shí)現(xiàn)方法,需要的朋友可以參考下2019-07-07Python寫一個(gè)基于MD5的文件監(jiān)聽程序
這篇文章主要給大家介紹了關(guān)于利用Python如何寫一個(gè)基于MD5的文件監(jiān)聽程序的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03在Pytorch中簡(jiǎn)單使用tensorboard
今天給大家?guī)淼氖顷P(guān)于Python的相關(guān)知識(shí),文章圍繞著Pytorch使用tensorboard展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06django 自定義filter 判斷if var in list的例子
今天小編就為大家分享一篇django 自定義filter 判斷if var in list的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-08-08如何將自己的python代碼發(fā)布在pip install給別人使用你知道嗎
這篇文章主要介紹了python如何發(fā)布自已的pip項(xiàng)目,方便大家學(xué)習(xí),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2021-08-08正確理解Python中if __name__ == ''__main__''
今天小編就為大家分享一篇關(guān)于正確理解Python中if __name__ == '__main__' ,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01