celery

celery

情景:用戶發起request,並等待response返回。在本些views中,可能需要執行一段耗時的程序,那麼用戶就會等待很長時間,造成不好的用戶體驗,比如發送郵件、手機驗證碼等。

使用celery後,情況就不一樣了。解決:將耗時的程序放到celery中執行。

celery名詞:

  • 任務task:就是一個Python函數。
  • 隊列queue:將需要執行的任務加入到隊列中。
  • 工人worker:在一個新進程中,負責執行隊列中的任務。
  • 代理人broker:負責調度,在佈置環境中使用redis。

安裝包:

celery==3.1.25
django-celery==3.1.17

示例

1)在booktest/views.py文件中創建視圖sayhello。

import time
...
def sayhello(request):
    print('hello ...')
    time.sleep(2)
    print('world ...')
    return HttpResponse("hello world")

2)在booktest/urls.py中配置。

    url(r'^sayhello$',views.sayhello),

3)啓動服務器,在瀏覽器中輸入如下網址:

http://127.0.0.1:8000/sayhello/

4)在終端中效果如下圖,兩次輸出之間等待一段時間纔會返回結果。

5)在test6/settings.py中安裝。

INSTALLED_APPS = (
  ...
  'djcelery',
}

6)在test6/settings.py文件中配置代理和任務模塊。

import djcelery
djcelery.setup_loader()
BROKER_URL = 'redis://127.0.0.1:6379/2'

7)在booktest/目錄下創建tasks.py文件。

import time
from celery import task

@task
def sayhello():
    print('hello ...')
    time.sleep(2)
    print('world ...')

8)打開booktest/views.py文件,修改sayhello視圖如下:

from booktest import tasks
...
def sayhello(request):
    # print('hello ...')
    # time.sleep(2)
    # print('world ...')
    tasks.sayhello.delay()
    return HttpResponse("hello world")

9)執行遷移生成celery需要的數據表。

python manage.py migrate

生成表如下:

10)啓動Redis,如果已經啓動則不需要啓動。

sudo service redis start

11)啓動worker。

python manage.py celery worker --loglevel=info

啓動成功後提示如下圖:

11)打開新終端,進入虛擬環境,啓動服務器,刷新瀏覽器。 在舊終端中兩個輸出間仍有時間間隔。

運行完成後如下圖,注意兩個終端中的時間,服務器的響應是立即返回的。

12)打開booktest/task.py文件,修改爲發送郵件的代碼,就可以實現無阻塞發送郵件。

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)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章