国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

詳解配置Django的Celery異步之路踩坑

2020-01-04 14:00:07
字體:
供稿:網(wǎng)友

人生苦短,我用python。

看到這句話的時候,感覺可能確實是很深得人心,不過每每想學(xué)學(xué),就又止步,年紀大了,感覺學(xué)什么東西都很慢,很難,精神啊注意力啊思維啊都跟不上。今天奶牛來分享自己今天踩的一個坑。

先說說配置過程吧,初學(xué)Django,啥都不懂,當(dāng)然,python也很水,啥東西都得現(xiàn)查現(xiàn)用。Django安裝還是很簡單的。

apt-get install python3pip3 install django

嗯,就是兩條命令的事兒。

再說celery的安裝:

pip3 install celerypip3 install redis==2.10.6

目前奶牛所在的時間redis for python的版本是redis-3.0.1,為什么要用2.10.6呢?因為3.0.1壓根配置就無法運行!!!

繼續(xù)安裝redis server

apt-get install redisservice redis start

然后就可以按照celery的官方教程走了,放個URL:http://docs.celeryproject.org/en/latest/django/index.html

python3 manage.py startproject nenewcd nenewpython3 manage.py startapp nenewapptouch ./nenew/celery.pytouch ./nenewapp/tasks.py

然后增加nenew/nenew/celery.py內(nèi)容為

from __future__ import absolute_import, unicode_literalsimport osfrom celery import Celery# set the default Django settings module for the 'celery' program.os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'nenew.settings')app = Celery('nenew')# Using a string here means the worker doesn't have to serialize# the configuration object to child processes.# - namespace='CELERY' means all celery-related configuration keys#  should have a `CELERY_` prefix.app.config_from_object('django.conf:settings', namespace='CELERY')# Load task modules from all registered Django app configs.app.autodiscover_tasks()@app.task(bind=True)def debug_task(self):  print('Request: {0!r}'.format(self.request))

增加nenew/nenew/__init__.py的內(nèi)容

from __future__ import absolute_import, unicode_literals# This will make sure the app is always imported when# Django starts so that shared_task will use this app.from .celery import app as celery_app__all__ = ('celery_app',)

增加nenew/nenewtest/tasks.py的內(nèi)容

# Create your tasks herefrom __future__ import absolute_import, unicode_literalsfrom celery import shared_task@shared_taskdef add(x, y):  return x + y@shared_taskdef mul(x, y):  return x * y@shared_taskdef xsum(numbers):  return sum(numbers)

在nenew/nenew/settings.py中增加和修改

...ALLOWED_HOSTS = ['*']....INSTALLED_APPS = [...  'nenewtest',]...CELERY_BROKER_URL = 'redis://localhost:6379/1'CELERY_RESULT_BACKEND = ‘redis://localhost:6379/0'

在nenew/nenewtest/views.py中增加或修改為

from django.shortcuts import renderfrom django.http import HttpResponsefrom .tasks import add# Create your views here.def nenewtest(request):  result = add.delay('2','2')  result.ready()  return HttpResponse('nenew Django Celery worker run !')

最后把views添加到nenew/nenew/urls.py中

from django.contrib import adminfrom django.urls import pathfrom nenewtest import viewsurlpatterns = [  path('admin/', admin.site.urls),  path('test/', views.nenewtest),]

然后在項目目錄nenew執(zhí)行

celery -A nenew worker -l info

這時候worker啟動正常會顯示:

-------------- <a href="/cdn-cgi/l/email-protection" rel="external nofollow" data-cfemail="2c4f4940495e556c424942495b">[email protected]</a> v4.2.1 (windowlicker)
---- **** -----
--- * ***  * -- Linux-4.15.0-39-generic-x86_64-with-Ubuntu-18.04-bionic 2018-11-23 17:31:25
-- * - **** ---
- ** ---------- [config]
- ** ---------- .> app:         nenew:0x7fdc5a155cc0
- ** ---------- .> transport:   redis://localhost:6379/1
- ** ---------- .> results:     redis://localhost:6379/0
- *** --- * --- .> concurrency: 1 (prefork)
-- ******* ---- .> task events: OFF (enable -E to monitor tasks in this worker)
--- ***** -----
 -------------- [queues]
                .> celery           exchange=celery(direct) key=celery

這樣類似的信息,然后我們啟動項目,這里需要新開一個shell:

python3 manage.py runserver 0:80

這樣我們就可以通過80端口直接訪問我們的web了。地址是http://locahost/test

當(dāng)我們這里訪問正常后,在worker界面會有

[2018-11-23 18:09:19,469: INFO/MainProcess] Received task: nenewtest.tasks.add[35faa0fe-dd48-4f8d-9559-516556a93a40]
[2018-11-23 18:09:19,470: INFO/ForkPoolWorker-1] Task nenewtest.tasks.add[35faa0fe-dd48-4f8d-9559-516556a93a40] succeeded in 0.00031037399821798317s: '22'

如下語句表示執(zhí)行成功,這樣子就表示通過Django的網(wǎng)頁我們對celery任務(wù)的異步執(zhí)行成功。

當(dāng)然,按照我的方法是可以一步成功的,因為奶牛已經(jīng)踩了一整天的坑了,被一個錯誤郁悶得不要不要的。

AttributeError: 'float' object has no attribute 'items'

就是這個錯誤,查遍國內(nèi)的所有網(wǎng)站都沒有結(jié)果,然后就去bing的國際版查,然后發(fā)現(xiàn)果然是有bug在啊,奶牛這一天浪費得可真是夠了。

這是celery的一個issue,在地址https://github.com/celery/celery/issues/5175 ,issue里面提及在2018/11/22日 it's fixed in kombu and celery master。問題的根源是celery對redis3的支持不好,補救方法是

Solution: Roll back redis with pip: pip install redis==2.10.6

然后在commit里面找到是對requirements/extras/redis.txt文件進行版本限定。

-redis>=2.10.5+redis>=2.10.5,<3

好了,踩坑總算結(jié)束了。畢竟是新手,很多問題可能就是潛意識認為是自己的代碼有問題,實際。。。實際可能并不是這樣子,得多關(guān)注源碼的更迭和問題處理才好。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到python教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 社会| 常德市| 长武县| 凤城市| 丹寨县| 广宗县| 桃园县| 隆子县| 九龙城区| 上栗县| 普兰县| 郑州市| 兴仁县| 合作市| 社会| 屏东市| 海南省| 惠安县| 电白县| 永吉县| 新源县| 桃江县| 平定县| 龙里县| 治多县| 建昌县| 襄樊市| 石嘴山市| 新疆| 嘉义市| 攀枝花市| 双江| 夹江县| 龙门县| 邵东县| 徐州市| 泌阳县| 聂荣县| 军事| 噶尔县| 库尔勒市|