Celery+django+redis異步執(zhí)行任務的實現(xiàn)示例
本文用到的各工具版本:
- celery 4.0.2
- django 1.10.3
- redis 3.2.6
特別注意:
如果你的項目是django框架,那么django-celery,celery-with-redis等等這些東西,都不要用了(這些東西會受python、celery版本的影響,我一直沒測通…)。直接pip安裝celery 4版本以上,pip安裝redis就完全可以的
1.安裝redis
二進制文件是編譯完成后在src目錄下,通過下面的命令啟動Redis服務:
$ src/redis-server
你可以使用內(nèi)置的客戶端命令redis-cli進行使用:
$ src/redis-cli redis> set foo bar OK redis> get foo “bar”
下載,解壓,編譯:
# wget http://download.redis.io/releases/redis-3.2.6.tar.gz # tar xzf redis-3.2.6.tar.gz # cd redis-3.2.6 # make # src/redis-server # 啟動redis服務,看清楚,這是在你的redis-3.2.6目錄下執(zhí)行的 # src/redis-cli # 啟動客戶端
2.安裝celery,redis
# pip install celery # pip install redis
3.創(chuàng)建一個task
在django app目錄中創(chuàng)建tasks.py:
import time from celery import task @task() def add(x, y): return x + y @task def sendmail(mail): print "++++++++++++++++++++++++++++++++++++" print('sending mail to %s...' % mail['to']) time.sleep(2.0) print('mail sent.') print "------------------------------------" return mail['to']
4.開啟worker
# celery -A tasks worker --loglevel=info
注意: 上面命令中的tasks是你創(chuàng)建的task所在的python 文件名稱。如果你創(chuàng)建的這個tasks.py文件在app文件夾內(nèi),那么你要這么執(zhí)行:
# celery -A app.tasks worker --loglevel=info
注意:每次更改tasks.py文件中的代碼后,都要重新執(zhí)行此命令!
5.試一下
>>> from app.tasks import * >>> sendmail.delay(dict(to='asd@as.com')) <AsyncResult: 694b6fa8-a123-4c22-9ba2-b77d7cbb066f> >>> add.delay(2, 15) <AsyncResult: 42d34419-4a34-49ab-9627-45428eaaeb38> >>> a=add.delay(1,1) >>> a.ready() True >>> a.get() 2 >>> a=add.delay(10,5) >>> a.get() 15
6.實例
# views.py
from app.tasks import add,sendmail def task_workorder(request, id): """任務添加""" # ......你的代碼...... sendmail.delay(dict(to='asd@as.com')) #申請人提交后會給審批人發(fā)郵件 # ......你的代碼......
注意:如果執(zhí)行成功,你運行celery -A app.tasks worker –loglevel=info命令的終端會打印一些內(nèi)容;如果執(zhí)行失敗,報一大把紅色代碼。。。那么恭喜你!出錯了!這種錯誤,一般都是與你傳的參數(shù)相關,尤其在django框架下,不要將queryset這種數(shù)據(jù)查詢結果直接傳遞。
到此這篇關于Celery+django+redis異步執(zhí)行任務的實現(xiàn)示例的文章就介紹到這了,更多相關Celery+django+redis異步執(zhí)行內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python+request+unittest實現(xiàn)接口測試框架集成實例
這篇文章主要介紹了Python+request+unittest實現(xiàn)接口測試框架集成實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03python環(huán)境功能強大的pip-audit安全漏洞掃描工具
這篇文章主要為大家介紹了python環(huán)境中功能強大的pip-audit安全漏洞掃描工具的功能介紹及安裝使用說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-02-02使用Python實現(xiàn)從各個子文件夾中復制指定文件的方法
今天小編就為大家分享一篇使用Python實現(xiàn)從各個子文件夾中復制指定文件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10