Python Celery異步任務隊列使用方法解析
Celery是一個異步的任務隊列(也叫做分布式任務隊列),一個簡單,靈活,可靠的分布式系統(tǒng),用于處理大量消息,同時為操作提供維護此類系統(tǒng)所需要的工具。
celery的優(yōu)點
1:簡單,容易使用,不需要配置文件
2:高可用,任務執(zhí)行失敗或執(zhí)行過程中發(fā)生連續(xù)中斷,celery會自動嘗試重新執(zhí)行任務
3:快速,一個單進程的celery每分鐘可以處理上百萬個任務
4:靈活,幾乎celery的各個組件都可以被擴展
celery應用場景
1:異步發(fā)郵件,一般發(fā)郵件等比較耗時的操作,這個時候需要提交任務給celery就可以了,由worker進行發(fā)郵件操作
2:有些跑批量接口任務,需要耗時較長,也可以做成異步任務
3:定時調(diào)度任務
Celery與Django一起使用(以發(fā)送短信為例)
獨立于項目新建一個package包
在package包中新建一個名為sms的package包
新建tasks.py文件
#定義耗時的函數(shù) from utils.ytx_sdk.sendSMS import CCP from celery_tasks.main import app #為函數(shù)添加裝飾器,這個函數(shù)就成為了celery的任務 @app.task def send_sms_code(mobile,code,expires,template_id): try: # CCP.sendTemplateSMS(mobile,code,expires,template_id) print(code) except: return '發(fā)送短信失敗'
在package包中新建config.py
內(nèi)容如下(中間人,接收生產(chǎn)者發(fā)來的消息即Task,將任務存入隊列。任務的消費者是Worker。Celery本身不提供隊列服務,推薦用Redis或RabbitMQ實現(xiàn)隊列服務。)
#指定代理人隊列==>redis
broker_url='redis://127.0.0.1:6379/15'
在package包中新建main.py
內(nèi)容如下(需要將task注冊到celery應用中)
#啟動工人的文件 from celery import Celery # 為celery使用django配置文件進行設置 import os if not os.getenv('DJANGO_SETTINGS_MODULE'): os.environ['DJANGO_SETTINGS_MODULE'] = 'yinyue.settings.dev' # 創(chuàng)建celery應用 app = Celery('yinyue') # 導入celery配置 app.config_from_object('celery_tasks.config') # 自動注冊celery任務 app.autodiscover_tasks([ 'celery_tasks.sms' ])
在django框架對應模塊的視圖中使用
#調(diào)用celery的任務:任務名.delay(參數(shù))
send_sms_code.delay(mobile,code,constants.SMS_CODE_EXPIRES/60,1)
啟動celery服務: celery -A celery_tasks.main worker -l info
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
雙向RNN:bidirectional_dynamic_rnn()函數(shù)的使用詳解
今天小編就為大家分享一篇雙向RNN:bidirectional_dynamic_rnn()函數(shù)的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01python如何用pymodbus庫進行modbus tcp通信
這篇文章主要介紹了python如何用pymodbus庫進行modbus tcp通信問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06Python中.py程序在CMD控制臺以指定虛擬環(huán)境運行
本文主要介紹了Python中.py程序在CMD控制臺以指定虛擬環(huán)境運行,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-07-07Python多線程編程(三):threading.Thread類的重要函數(shù)和方法
這篇文章主要介紹了Python多線程編程(三):threading.Thread類的重要函數(shù)和方法,本文講解了線程名稱、join方法、setDaemon方法等內(nèi)容,需要的朋友可以參考下2015-04-04python中時間、日期、時間戳的轉(zhuǎn)換的實現(xiàn)方法
這篇文章主要介紹了python中時間、日期、時間戳的轉(zhuǎn)換的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-07-07python opencv實現(xiàn)旋轉(zhuǎn)矩形框裁減功能
這篇文章主要為大家詳細介紹了python opencv實現(xiàn)旋轉(zhuǎn)矩形框裁減功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07