django celery redis使用具體實(shí)踐
環(huán)境準(zhǔn)備
- python3.5.4
- windows redis
- pip install celery
- pip install redis
windows下啟動(dòng)redirs server
redis-server.exe redis.windows.conf
celery配置
項(xiàng)目的settings.py文件修改:
# celery 設(shè)置 # celery中間人 redis://redis服務(wù)所在的ip地址:端口/數(shù)據(jù)庫號(hào) BROKER_URL = 'redis://127.0.0.1:6379/0' # celery結(jié)果返回,可用于跟蹤結(jié)果 CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/0' # celery內(nèi)容等消息的格式設(shè)置 CELERY_ACCEPT_CONTENT = ['application/json', ] CELERY_TASK_SERIALIZER = 'json' CELERY_RESULT_SERIALIZER = 'json' # celery時(shí)區(qū)設(shè)置,使用settings中TIME_ZONE同樣的時(shí)區(qū) CELERY_TIMEZONE = TIME_ZONE
項(xiàng)目文件夾下添加celery.py文件:
# coding:utf-8 from __future__ import absolute_import, unicode_literals from celery import Celery from django.conf import settings import os # 獲取當(dāng)前文件夾名,即為該Django的項(xiàng)目名 project_name = os.path.split(os.path.abspath('.'))[-1] project_settings = '%s.settings' % project_name # 設(shè)置環(huán)境變量 os.environ.setdefault('DJANGO_SETTINGS_MODULE', project_settings) # 實(shí)例化Celery,網(wǎng)上很多教程這里都是沒有設(shè)置broker造成啟動(dòng)失敗 app = Celery('tasks', broker='redis://127.0.0.1:6379/0') # 使用django的settings文件配置celery app.config_from_object('django.conf:settings') # Celery加載所有注冊(cè)的應(yīng)用 app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
項(xiàng)目的init.py文件修改:
# 引入celery實(shí)例對(duì)象 from __future__ import absolute_import, unicode_literals from .celery import app as celery_app __all__ = ['celery_app]
測(cè)試代碼
- 如:在app01(項(xiàng)目名)/tasks.py:
- 關(guān)于task,并不是一定要把所有的task放在tasks.py,可以放在其他類里面,只要在函數(shù)上加@task即可
import time from celery import task @task def add(a,b): print("這是任務(wù)開始") print(a+b) time.sleep(10) print("這是任務(wù)結(jié)束")
url配置如下:
path('add', views.add, name="add")
view代碼
from . import tasks def add(request,*args,**kwargs): tasks.add.delay(1,2) result = {'code': 0, 'msg': '這是一個(gè)后臺(tái)任務(wù)'} return JsonResponse(result)
再次配置
在manger.py目錄執(zhí)行下面的代碼,注意網(wǎng)上的資料大部分執(zhí)行的命令有問題,造成啟動(dòng)報(bào)錯(cuò),比如這個(gè)就是錯(cuò)誤的, python manage.py celery -A celery worker --loglevel=info
,請(qǐng)用下面的命令
celery -A djangoApi worker --pool=solo -l info
啟動(dòng)項(xiàng)目, python manager.py runserver 0.0.0.0:8081
運(yùn)行項(xiàng)目
訪問add
查看關(guān)鍵日志
[tasks] . api.base.BaseViewTask.task_run . api.tasks.add [2019-04-07 13:26:02,855: INFO/MainProcess] Connected to redis://127.0.0.1:6379/0 [2019-04-07 13:26:02,869: INFO/MainProcess] mingle: searching for neighbors [2019-04-07 13:26:03,911: INFO/MainProcess] mingle: all alone [2019-04-07 13:26:03,926: WARNING/MainProcess] e:\app\python35\lib\site-packages\celery\fixups\django.py:202: UserWarning: Using settings.DEBUG leads to a memory leak, never use this setting in production environments! warnings.warn('Using settings.DEBUG leads to a memory leak, never ' [2019-04-07 13:26:03,926: INFO/MainProcess] celery@PC-20181208QWQO ready. [2019-04-07 13:29:56,889: INFO/MainProcess] Received task: api.tasks.add[9fd98fd0-50ae-427f-8f33-52d1e4b43068] [2019-04-07 13:29:56,894: WARNING/MainProcess] 這是任務(wù)開始 [2019-04-07 13:29:56,895: WARNING/MainProcess] 3 [2019-04-07 13:30:06,896: WARNING/MainProcess] 這是任務(wù)結(jié)束 [2019-04-07 13:30:06,898: INFO/MainProcess] Task api.tasks.add[9fd98fd0-50ae-427f-8f33-52d1e4b43068] succeeded in 10.0s: None
其他
如何結(jié)合前端,如ajax來聯(lián)合使用?
- 表中我加了個(gè)extend字段,每次在執(zhí)行耗時(shí)任務(wù)后,頁面按鈕根據(jù)extend字段值進(jìn)行判斷
- 如1表示執(zhí)行中,0表示沒有執(zhí)行,2執(zhí)行完成,來判定按鈕是否可以再次點(diǎn)擊等
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
selenium+python設(shè)置爬蟲代理IP的方法
這篇文章主要介紹了selenium+python設(shè)置爬蟲代理IP的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11Python對(duì)接六大主流數(shù)據(jù)庫(只需三步)
這篇文章主要介紹了Python對(duì)接六大主流數(shù)據(jù)庫(只需三步),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python實(shí)現(xiàn)疫苗接種管理數(shù)據(jù)庫步驟詳解
這篇文章主要為大家介紹了Python實(shí)現(xiàn)疫苗接種管理數(shù)據(jù)庫步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09matplotlib源碼解析標(biāo)題實(shí)現(xiàn)(窗口標(biāo)題,標(biāo)題,子圖標(biāo)題不同之間的差異)
這篇文章主要介紹了matplotlib源碼解析標(biāo)題實(shí)現(xiàn)(窗口標(biāo)題,標(biāo)題,子圖標(biāo)題不同之間的差異),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02django 微信網(wǎng)頁授權(quán)認(rèn)證api的步驟詳解
這篇文章主要介紹了django 微信網(wǎng)頁授權(quán)認(rèn)證api的步驟詳解,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07自動(dòng)化測(cè)試時(shí)基于Python常用的幾個(gè)加密算法總結(jié)
這幾天做自動(dòng)化測(cè)試,遇到一個(gè)問題,那就是接口的請(qǐng)求的密碼是加密的,產(chǎn)品的要求是不能使用使用其他特殊手段,他給提供加密算法,需要在接口請(qǐng)求的時(shí)候,使用加密算法處理后的數(shù)據(jù)傳參,本文主要是整理了幾個(gè)加密算法,以便后續(xù)測(cè)試使用,需要的朋友可以參考下2023-12-12Python中使用sklearn進(jìn)行特征降維的方法
在Python中,可以使用sklearn庫中的特征降維方法對(duì)數(shù)據(jù)進(jìn)行處理。主要包括基于PCA算法的降維、基于LDA算法的降維、以及利用特征選擇方法進(jìn)行降維。這些方法可以提高模型的訓(xùn)練效率和預(yù)測(cè)準(zhǔn)確率,特別是在高維數(shù)據(jù)集中具有重要的作用2023-04-04