亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用celery執(zhí)行Django串行異步任務(wù)的方法步驟

 更新時(shí)間:2019年06月06日 08:59:40   作者:luozx207  
這篇文章主要介紹了使用celery執(zhí)行Django串行異步任務(wù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Django具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

Django項(xiàng)目有一個(gè)耗時(shí)較長(zhǎng)的update過(guò)程,希望在接到請(qǐng)求運(yùn)行update過(guò)程的時(shí)候,Django應(yīng)用仍能正常處理其他的請(qǐng)求,并且update過(guò)程要求不能并行,也不能漏掉任何一個(gè)請(qǐng)求

使用celery的solo模式解決

安裝redis

https://github.com/microsoftarchive/redis/releases

下載.msi文件安裝,會(huì)直接將redis注冊(cè)為windows服務(wù)

安裝celery與redis依賴(lài)

pip install celery
pip indatll redis

一個(gè)celery應(yīng)用

# celery_test.py
import time

from celery import Celery

app = Celery('tasks', broker='redis://127.0.0.1:6379/0')


@app.task
def add(x, y):
 time.sleep(5)
 return x + y

啟動(dòng)celery服務(wù)

celery -A celery_test.app worker --pool=solo -l info

查看完整的命令行參數(shù)列表

celery worker --help

對(duì)celery啟動(dòng)命令的解釋

  • '-A' 是一個(gè)全局配置,定義了APP的位置
  • '--pool' 是POOL的配置,默認(rèn)是prefork(并發(fā)),選擇solo之后,發(fā)送的任務(wù)不會(huì)被并發(fā)執(zhí)行,在worker執(zhí)行任務(wù)過(guò)程中,再次發(fā)送給worker的任務(wù)會(huì)排隊(duì),執(zhí)行完一個(gè)再執(zhí)行另一個(gè)
  • '-l' 是WORKER的配置,定義了log級(jí)別

調(diào)用任務(wù)

>>> from celery_test import add
>>> add.delay(4,4)

因?yàn)閱?dòng)了solo模式,因此,可以看到在一個(gè)add沒(méi)有執(zhí)行完前,即使再次發(fā)送執(zhí)行add的任務(wù),celery worker也會(huì)等到前一個(gè)任務(wù)執(zhí)行完才去執(zhí)行下一個(gè)

與Django結(jié)合

在裝載celery應(yīng)用前先setup django

import time
import os
import django
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "demo.settings")
django.setup()

from celery import Celery

from django_app.update import update

app = Celery('tasks', broker='redis://127.0.0.1:6379/0', backend='redis://127.0.0.1:6379/0')

@app.task
def update_task():
 update()

然后在views中調(diào)用task就可以了。

from celery_test import update_task
def update_api(request):
 if request.method == "GET":
  update_task.delay()
  return HttpResponse(status=status.HTTP_200_OK)

執(zhí)行過(guò)程中,程序的print信息會(huì)作為celery warning,報(bào)錯(cuò)信息會(huì)作為celery error

日志

在啟動(dòng)應(yīng)用的時(shí)候指定日志文件路徑

-f log_path

不設(shè)置這個(gè)參數(shù)的時(shí)候,日志默認(rèn)輸出到控制臺(tái)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python在字符串中處理html和xml的方法

    Python在字符串中處理html和xml的方法

    這篇文章主要介紹了Python在字符串中處理html和xml的方法,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • Python random模塊用法解析及簡(jiǎn)單示例

    Python random模塊用法解析及簡(jiǎn)單示例

    這篇文章主要介紹了Python random模塊用法解析及簡(jiǎn)單示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • python使用pipeline批量讀寫(xiě)redis的方法

    python使用pipeline批量讀寫(xiě)redis的方法

    今天小編就為大家分享一篇python使用pipeline批量讀寫(xiě)redis的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • 詳解python配置虛擬環(huán)境

    詳解python配置虛擬環(huán)境

    這篇文章主要介紹了python配置虛擬環(huán)境,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Python基于多線(xiàn)程實(shí)現(xiàn)ping掃描功能示例

    Python基于多線(xiàn)程實(shí)現(xiàn)ping掃描功能示例

    這篇文章主要介紹了Python基于多線(xiàn)程實(shí)現(xiàn)ping掃描功能,結(jié)合實(shí)例形式分析了Python多線(xiàn)程與進(jìn)程相關(guān)模塊調(diào)用操作技巧,需要的朋友可以參考下
    2018-07-07
  • Python命令行參數(shù)解析包argparse的使用詳解

    Python命令行參數(shù)解析包argparse的使用詳解

    argparse?是?python?自帶的命令行參數(shù)解析包,可以用來(lái)方便的服務(wù)命令行參數(shù)。本文將通過(guò)示例和大家詳細(xì)講講argparse的使用,需要的可以參考一下
    2022-09-09
  • 通過(guò) Django Pagination 實(shí)現(xiàn)簡(jiǎn)單分頁(yè)功能

    通過(guò) Django Pagination 實(shí)現(xiàn)簡(jiǎn)單分頁(yè)功能

    這篇文章主要介紹了通過(guò) Django Pagination 實(shí)現(xiàn)簡(jiǎn)單分頁(yè)功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Python生成requirements.txt的三種方法

    Python生成requirements.txt的三種方法

    requirements.txt?文件通常用于列出項(xiàng)目所需的所有Python包及其版本,本文主要介紹了Python生成requirements.txt的三種方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • Mac中升級(jí)Python2.7到Python3.5步驟詳解

    Mac中升級(jí)Python2.7到Python3.5步驟詳解

    本篇文章主要介紹了Mac中升級(jí)Python2.7到Python3.5步驟詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-04-04
  • pandas提取數(shù)據(jù)的6種方法匯總

    pandas提取數(shù)據(jù)的6種方法匯總

    這篇文章主要介紹了pandas提取數(shù)據(jù)的6種方法匯總,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08

最新評(píng)論