celery
性能優化的工具。
django是單進程的,celery可以在django框架內部開闢開啓一個新進程,用來處理耗時的工做。
這樣的好處是,用戶能夠快速得到響應。html
celery的4個概念
任務task:就是一個Python函數
隊列queue:將須要執行的任務加入到隊列中
工人worker:在一個新進程中,負責執行隊列中的任務
代理人broker:負責調度,在佈置環境中使用redis。相似車間的隊長,安排任務分配給工人幹。python
celery官方文檔
中文:http://docs.jinkan.org/docs/celery/redis
何時用celery
一、耗時
二、和響應結果不要緊django
安裝包
celery==3.1.25
celery-with-redis==3.0
django-celery==3.1.17瀏覽器
示例性能優化
import time ... def sayhello(request): print('hello ...') time.sleep(2) print('world ...') return HttpResponse("hello world")
url(r'^sayhello$',views.sayhello),
http://127.0.0.1:8000/sayhello/
INSTALLED_APPS = ( ... 'djcelery', }
import djcelery djcelery.setup_loader() BROKER_URL = 'redis://127.0.0.1:6379/2' CELERY_IMPORTS = ('booktest.task')
import time from celery import task @task def sayhello(): print('hello ...') time.sleep(2) print('world ...')
from . import task ... def sayhello(request): # print('hello ...') # time.sleep(2) # print('world ...') task.sayhello.delay() return HttpResponse("hello world")
python manage.py migrate
sudo service redis start
python manage.py celery worker --loglevel=info
#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://127.0.0.1/user/active/" target="_blank">點擊激活</a>' send_mail('註冊激活','',settings.EMAIL_FROM, ['itcast88@163.com'], html_message=msg)