欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何使用celery進(jìn)行異步處理和定時(shí)任務(wù)(django)

 更新時(shí)間:2025年01月10日 15:57:48   作者:_BooI  
文章介紹了Celery的基本概念、安裝方法、如何使用Celery進(jìn)行異步任務(wù)處理以及如何設(shè)置定時(shí)任務(wù),通過(guò)Celery,可以在Web應(yīng)用中處理后臺(tái)任務(wù),如發(fā)送郵件、視頻轉(zhuǎn)碼等,而不阻塞Web請(qǐng)求,文章還提到了啟動(dòng)Celery worker和beat的命令以及任務(wù)和定時(shí)任務(wù)的執(zhí)行效果

一、celery的作用

celery 是一個(gè)簡(jiǎn)單、靈活且可靠的分布式系統(tǒng),用于處理大量消息,同時(shí)為操作提供一致的接口。它專注于實(shí)時(shí)操作,但支持任務(wù)調(diào)度。

Celery 主要用于異步任務(wù)處理,特別是在Web應(yīng)用環(huán)境中,用于執(zhí)行后臺(tái)任務(wù),如發(fā)送電子郵件、處理圖片、視頻轉(zhuǎn)碼、運(yùn)行復(fù)雜的計(jì)算等,而不必阻塞Web請(qǐng)求/響應(yīng)周期。

二、安裝celery

命令:

pip install celery -i https://pypi.tuna.tsinghua.edu.cn/simple

三、使用celery 異步執(zhí)行任務(wù)

官方文檔:First steps with Django — Celery 5.4.0 documentation (celeryq.dev)

1、配置

  • 1)給celery設(shè)置環(huán)境,為django項(xiàng)目的環(huán)境
  • 2)創(chuàng)建celery實(shí)例
  • 3)設(shè)置broker,也就是我們存放任務(wù)的隊(duì)列,這里從配置文件中加載broker
  • 4)設(shè)置自動(dòng)檢測(cè)任務(wù),autodiscover_tasks方法

具體實(shí)現(xiàn)如下:

broker配置文件如下,這里用redis做隊(duì)列來(lái)存任務(wù):

2、創(chuàng)建好celery實(shí)例和配置broker之后,開(kāi)始創(chuàng)建任務(wù)

比如我要?jiǎng)?chuàng)建一個(gè)發(fā)送郵件的任務(wù):

  • 1)創(chuàng)建文件夾,創(chuàng)建tasks.py文件

  • 2)在tasks.py文件中編寫(xiě)任務(wù)(函數(shù)), 一定要用task裝飾器修飾起來(lái)

  • 3)在app.autodiscover_tasks([ ])中添加你的任務(wù)

參數(shù)是列表,列表中的元素是task的路徑(就是要執(zhí)行的任務(wù)所在的路徑)

  • 4)在你想要異步執(zhí)行該函數(shù)的地方導(dǎo)入,用delay方法將任務(wù)推到隊(duì)列中

四、使用celery定期執(zhí)行任務(wù)

官方文檔:Periodic Tasks — Celery 5.4.0 documentation (celeryq.dev)

1、創(chuàng)建一個(gè)文件,專門(mén)用來(lái)放定時(shí)任務(wù)的配置(也可以不用)

  • task就是要執(zhí)行的定時(shí)任務(wù), 注意位置要找對(duì),要找到對(duì)應(yīng)的函數(shù)
  • schedule執(zhí)行的周期

2、用 app.conf.beat_schedule 來(lái)指定我們的定時(shí)任務(wù)

3、在app.autodiscover_tasks([ ])中添加你的任務(wù)

參數(shù)是列表,列表中的元素是task的路徑(就是要執(zhí)行的任務(wù)所在的路徑)

五、啟動(dòng)命令

  • 命令:Celery -A celery實(shí)例腳本文件 worker --loglevel=INFO
  • linux命令:celery -A celery_tasks.main worker --loglevel=INFO
  • windows命令:celery -A celery_tasks.main worker --concurrency=4 --loglevel=INFO -P threads

定時(shí)任務(wù),需要開(kāi)兩個(gè)終端分別執(zhí)行兩條命令,celery_tasks.main替換成你自己的腳本文件

  • 1、celery -A celery_tasks.main worker --concurrency=4- -loglevel=INFO -P threads
  • 2、celery -A celery_tasks.main beat --loglevel=INFO

六、 效果展示

任務(wù)的執(zhí)行

定期任務(wù)的執(zhí)行

七、具體文件目錄

  • main.py
'''
1、生產(chǎn)者
2、消費(fèi)者
使用命令(linux):celery -A celery實(shí)例腳本文件 worker -l info  啟動(dòng)進(jìn)程,消費(fèi)者拿任務(wù), 終端執(zhí)行
windows命令:celery -A celery_tasks.main worker --concurrency=4 --loglevel=INFO -P threads
3、消息隊(duì)列
'''
 
import os
from celery import Celery
 
# 為celery設(shè)置環(huán)境
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mall_test.settings")
 
# 創(chuàng)建celery實(shí)例
app = Celery('celery_tasks')
 
# 設(shè)置broker,消息隊(duì)列, 從配置信息中加載
app.config_from_object('celery_tasks.config')
 
# 讓celery自動(dòng)檢測(cè)指定包的任務(wù)
# 參數(shù)是列表,列表中的元素是task的路徑(就是要執(zhí)行的任務(wù)所在的路徑)
app.autodiscover_tasks(['celery_tasks.sms', 'celery_tasks.email', 'celery_tasks.generate_static'])
 
# 定時(shí)任務(wù)
from celery_tasks.celery_beat_schedule import CELERY_BEAT_SCHEDULE
app.conf.beat_schedule = CELERY_BEAT_SCHEDULE  # 加入定時(shí)任務(wù)
  • config.py
# 設(shè)置消息隊(duì)列,用redis實(shí)現(xiàn)
broker_url = 'redis://127.0.0.1:6379/15'
  • celery_beat_schedule.py
from celery.schedules import crontab
 
# 定時(shí)任務(wù), 可以添加多個(gè),啟動(dòng)命令
CELERY_BEAT_SCHEDULE = {
    'update-html': {
        'task': 'celery_tasks.generate_static.tasks.generate_static_index_html',  # 找到對(duì)應(yīng)函數(shù)即可
        'schedule': crontab(minute='*/1'),  # 周期,這里是30分鐘分鐘
    },
}

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 解決Keras使用GPU資源耗盡的問(wèn)題

    解決Keras使用GPU資源耗盡的問(wèn)題

    這篇文章主要介紹了解決Keras使用GPU資源耗盡的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-06-06
  • 利用Python如何生成hash值示例詳解

    利用Python如何生成hash值示例詳解

    這篇文章主要給大家介紹了關(guān)于利用Python如何生成hash值的相關(guān)資料,并且給大家分享了利用Python一句話校驗(yàn)軟件哈希值的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12
  • 在Python 不同級(jí)目錄之間模塊的調(diào)用方法

    在Python 不同級(jí)目錄之間模塊的調(diào)用方法

    今天小編就為大家分享一篇在Python 不同級(jí)目錄之間模塊的調(diào)用方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Python基于Opencv識(shí)別兩張相似圖片

    Python基于Opencv識(shí)別兩張相似圖片

    這篇文章主要介紹了Python基于Opencv識(shí)別兩張相似圖片的步驟,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下
    2021-04-04
  • PyTorch模型調(diào)試與故障排除指南

    PyTorch模型調(diào)試與故障排除指南

    在當(dāng)代深度學(xué)習(xí)領(lǐng)域,PyTorch 已成為開(kāi)發(fā)和訓(xùn)練神經(jīng)網(wǎng)絡(luò)的主要框架之一,然而隨著模型復(fù)雜度的增加和數(shù)據(jù)規(guī)模的擴(kuò)大,開(kāi)發(fā)者常常面臨各種調(diào)試和優(yōu)化挑戰(zhàn),本文旨在為 PyTorch 開(kāi)發(fā)者提供一個(gè)全面的調(diào)試指南,涵蓋從基礎(chǔ)概念到高級(jí)技術(shù)的廣泛內(nèi)容,需要的朋友可以參考下
    2024-09-09
  • python中dict獲取關(guān)鍵字與值的實(shí)現(xiàn)

    python中dict獲取關(guān)鍵字與值的實(shí)現(xiàn)

    這篇文章主要介紹了python中dict獲取關(guān)鍵字與值的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Python Loguru輕松靈活的日志管理庫(kù)基本用法探索

    Python Loguru輕松靈活的日志管理庫(kù)基本用法探索

    Loguru是一個(gè)用于Python的高性能、簡(jiǎn)潔且靈活的日志庫(kù),它的目標(biāo)是提供一種簡(jiǎn)單的方式來(lái)記錄應(yīng)用程序的運(yùn)行情況,同時(shí)保持代碼的簡(jiǎn)潔性和可讀性,本文將探索loguru的基本用法
    2024-01-01
  • python2與python3爬蟲(chóng)中g(shù)et與post對(duì)比解析

    python2與python3爬蟲(chóng)中g(shù)et與post對(duì)比解析

    這篇文章主要介紹了python2與python3爬蟲(chóng)中g(shù)et與post對(duì)比解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • python利用pandas分析學(xué)生期末成績(jī)實(shí)例代碼

    python利用pandas分析學(xué)生期末成績(jī)實(shí)例代碼

    pandas是數(shù)據(jù)分析師最常用的工具之一,這篇文章主要給大家介紹了關(guān)于python如何利用pandas分析學(xué)生期末成績(jī)的相關(guān)資料,文中給出了詳細(xì)的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2021-07-07
  • 使用numpy.mean()?計(jì)算矩陣均值方式

    使用numpy.mean()?計(jì)算矩陣均值方式

    這篇文章主要介紹了numpy.mean()?計(jì)算矩陣均值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評(píng)論