celery筆記四之在Django中使用celery

来源:https://www.cnblogs.com/hunterxiong/archive/2023/06/15/17484051.html
-Advertisement-
Play Games

> 本文首發於公眾號:Hunter後端 > 原文鏈接:[celery筆記四之在Django中使用celery](https://mp.weixin.qq.com/s/O-vHxvDbU6aSGM63GwLLdw) 這一篇筆記介紹一下如何在 Django 系統中使用 celery。 如果是想純粹使用 ...


本文首發於公眾號:Hunter後端
原文鏈接:celery筆記四之在Django中使用celery

這一篇筆記介紹一下如何在 Django 系統中使用 celery。

如果是想純粹使用 celery,這一篇筆記可以略過。

本篇筆記目錄如下:

  1. 文件配置
  2. task 定義
  3. 運行 worker

1、文件配置

我們這裡使用前面的創建的 hunter Django 系統。

我們需要在 settings.py 所在的文件夾下配置如下幾個文件:

hunter/hunter/
        /__init__.py
        /celery.py
        /settings.py

其中,celery.py 文件是我們需要新建的,其他的兩個我們需要新增一點配置項。

以下是 celery.py 文件內容:

# hunter/hunter/celery.py
import os
from celery import Celery

# 為 celery 程式設置預設的 Django 配置
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'hunter.settings')

app = Celery('hunter')

# 表示從 Django 的配置中載入 celery 的配置,namespace='CELERY' 表示 celery 的配置必須是以 'CELERY' 為首碼
app.config_from_object('django.conf:settings', namespace='CELERY')

app.conf.update(
    task_ignore_result=True
)

# 我們需要設置的定時任務 或者 延時任務都可以在對應的 application 下定義,task 的定義我們在下麵介紹
# 然後通過下麵的命令自動發現對應的任務
# 比如想要在 blog 下設置一個延時任務,可以創建 blog/tasks.py,然後 celery 就可以自己發現對應的任務
app.autodiscover_tasks()

在 Django 的 celery.py 里,不一樣的是,os.environ.setdefault() 函數設置了一個 Django 的配置

對 Celery() 實例化的時候,用到的是 Django 的系統名稱 hunter

而這裡使用到的 config_from_object() 用到的值是 'django.conf:settings',namespace 的值是 'CELERY',表示在 settings.py 中所有 CELERY 開頭的值都可以被捕捉到並作為 celery 的配置項,這個我們等下介紹。

最後面有一個 app.autodiscover_tasks() 表示Django 系統將會自動獲取 Django 系統下各個 application 的 tasks.py 的 task。

以上就是一個最基本的使用模板。

settings.py

在 settings.py 中的配置如下:

CELERY_ENABLE_UTC = False
CELERY_TIMEZONE = "Asia/Shanghai"
CELERY_BROKER_URL = "redis://localhost/0"
CELERY_RESULT_BACKEND = "redis://localhost/1"

其中,所有的關於 celery 的配置都需要加上 CELERY_ 的首碼,參數值的定義和之前 celeryconfig.py 中的定義方式是一致的。

還有很多其他的配置項對應值,詳見下麵的鏈接:celery配置項

除此之外,為了確保 celery 的 app 在 Django 運行的時候被載入,我們還需要在 hunter/hunter/init.py 中引入 celery_app。

# hunter/hunter/__init__.py
from .celery import app as celery_app

__all__ = ('celery_app',)

這樣,每個 application 下的 tasks.py 中被 @shared_task 修飾的延時或定時任務就可以使用了。

2、task 定義

假設我們還是沿用之前的 application,命名為 blog,我們在這個文件夾下創建一個 tasks.py,內容如下:

# blog/tasks.py
from celery import shared_task

@shared_task
def test_add(x, y):
    return x + y

在 Django 的 tasks 里我們會把 task 都寫在可重覆使用的 app 下,比如 blog,但是這些 app 不能依賴於項目本身,所以不能直接引入這些app實例

@shared_task 裝飾器可以讓你在不需要任何具體的 app 實例的情況下創建 task

以上是官方文檔給出的一段介紹,u1s1,我不太理解這段話的含義,但是我們照做就行了,就是在 Django 的 task 中,我們使用 @shared_task 來修飾那些 task 即可。

就此,我們將 celery 融入 Django 的操作就完成啦!

3、運行 worker

我們還是需要單獨將 worker 運行起來才可以調用延時任務

我們在 Django 系統的根目錄下,也就是 hunter/ 下,執行:

celery -A hunter worker -l INFO

然後新開一個 shell,在 Django 系統的根目錄下進入 Django 的 shell,也就是使用 python3 manage.py shell,然後調用 task:

from blog.tasks import test_add

test_add.delay(1, 2)

關於 celery 與 Django 的融合,還有一些其他操作,比如將 task 運行的 result 寫入 Django 的表,使用 Django 的表來設置定義任務等,這個我們後面再單開筆記來詳細介紹。

如果想獲取更多後端相關文章,可掃碼關註閱讀:
image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 微格式是一種用於在HTML文檔中嵌入語義化信息的簡單而輕量級的標記語言。它們通過使用已有的HTML標簽和類名來表示結構化數據,以便機器能夠更容易地理解和處理這些數據。 微格式的目標是為了讓信息更易於被自動化工具(如搜索引擎、數據聚合器、日曆應用程式等)提取和解析。通過添加特定的類名和屬性值,可以標記 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 使用ElementPlus的Table啥都好,就是沒有可編輯表格!!!😭 既然UI庫不支持,那我們實現一個可編輯表格是很難的事麽?😒難麽?😢不難麽?... 個人覺得如果是業務固定的可編輯表格,使用ElementPlus實現都不難。但 ...
  • 根據數據統計,我們可以得出結論:每年的618大促銷售額約占全年銷售額的10%左右。以2022年618大促銷售額為例,大促期間,每分鐘的銷售額平均高達1463萬元。因此,從技術角度來看,保證服務的穩定性是至關重要的。相信這些數據可以為您在大促期間制定任務優先順序和做出決策提供有價值的參考。 ...
  • 函數並非總是直接顯示輸出,它可以處理一些數據,並返回一個或一組值。函數返回的值被稱為返回值。 在函數中,可使用return關鍵字將值返回到調用函數的代碼行。返回值能夠將程式的大部分繁重工作移到函數中去,從而簡化主程式。函數可返回任何類型的值,包括列表和字典等較複雜的數據結構。 # 1.返回簡單值 返 ...
  • 某日二師兄參加XXX科技公司的C++工程師開發崗位第15面: > 面試官:瞭解`auto`關鍵字嗎? > > 二師兄:嗯,瞭解一些(我很熟悉)。 > > 面試官:說一說`auto`的用法吧? > > 二師兄:`auto`主要是為了編譯器進行類型推導。比如: ```c++ auto i = 42; / ...
  • 對於一個直接創建的springBoot項目工程來說,可以按照以下步驟使用rabbitmq - 添加依賴:添加rabbitMQ的依賴。 ~~~java org.springframework.boot spring-boot-starter-amqp ~~~ - 配置連接:在配置文件中配置虛擬主機、端 ...
  • 鑒於函數定義中可能包含多個形參變數,因此函數調用中也可能包含多個實參變數。向函數傳遞實參變數給形參變數的方式有很多,可使用**位置參數**,這要求實參變數的順序與形參變數的順序相同;也可使用**關鍵字參數**,都由變數名和值組成,簡稱名稱-值對;還可使用**列表(元組)和字典**。 # 1.位置參數 ...
  • # scala的基本語法 ## 註釋 對於scala的註釋,簡而言之就是一句話,和java的註釋一模一樣 基本語法 ``` (1)單行註釋:// (2)多行註釋:/* */ (3)文檔註釋:/** * */ ``` 代碼示例: ```Scala package com.doitedu.demo01 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...