- 情景:用戶發起request,並等待response返回。在本些views中,可能需要執行一段耗時的程序,那麼用戶就會等待很長時間,造成不好的用戶體驗,比如發送郵件、手機驗證碼等
- 使用celery後,情況就不一樣了
- 解決:將耗時的程序放到celery中執行
- 點擊查看celery官方網站
- 點擊查看celery中文文檔
- celery名詞
- 任務task:就是一個Python函數
- 隊列queue:將需要執行的任務加入到隊列中
- 工人worker:在一個新進程中,負責執行隊列中的任務
- 代理人broker:負責調度,在佈置環境中使用redis
- 安裝包
celery==3.1.25
celery-with-redis==3.0
django-celery==3.1.17
示例
- 在booktest/views.py文件中創建視圖sayhello
import time
...
def sayhello(request):
print('hello ...')
time.sleep(2)
print('world ...')
return HttpResponse("hello world")
- 在booktest/urls.py中配置
url(r'^sayhello$',views.sayhello),
- 啓動服務器,在瀏覽器中輸入如下網址
http://127.0.0.1:8000/sayhello/
- 在終端中效果如下圖,兩次輸出之間等待一段時間纔會返回結果
- 在test6/settings.py中安裝
INSTALLED_APPS = (
...
'djcelery',
}
- 在test6/settings.py文件中配置代理和任務模塊
import djcelery
djcelery.setup_loader()
BROKER_URL = 'redis://127.0.0.1:6379/2'
CELERY_IMPORTS = ('booktest.task')
- 在booktest/目錄下創建task.py文件
import time
from celery import task
@task
def sayhello():
print('hello ...')
time.sleep(2)
print('world ...')
- 打開booktest/views.py文件,修改sayhello視圖如下
from . import task
...
def sayhello(request):
# print('hello ...')
# time.sleep(2)
# print('world ...')
task.sayhello.delay()
return HttpResponse("hello world")
- 執行遷移生成celery需要的數據表
python manage.py migrate
- 生成表如下
- 啓動Redis,如果已經啓動則不需要啓動
sudo service redis start
- 啓動worker
python manage.py celery worker --loglevel=info
- 啓動成功後提示如下圖
- 打開新終端,進入虛擬環境,啓動服務器,刷新瀏覽器
- 在舊終端中兩個輸出間仍有時間間隔
- 運行完成後如下圖,注意兩個終端中的時間,服務器的響應是立即返回的
- 打開booktest/task.py文件,修改爲發送郵件的代碼,就可以實現無阻塞發送郵件
#coding=utf-8
from django.conf import settings
from django.core.mail import send_mail
from celery import task
@task
def sayhello():
msg='<a href="http://www.itcast.cn/subject/pythonzly/index.shtml" target="_blank">點擊激活</a>'
send_mail('註冊激活','',settings.EMAIL_FROM,
['[email protected]'],
html_message=msg)
--------------------- 作者:幸福清風 來源:CSDN 原文:https://blog.csdn.net/xun527/article/details/78374281?utm_source=copy