2017-12-20 3 views
1

ここではセロリとジャンゴノブの総称ですので、問題が些細な場合はごめんなさい。基本的に問題は、@ app.taskで定義された関数がセロリによって処理されていないことです。セロリが存在しないかのように正常に実行されます。セロリで処理されていないセロリのタスク

マイcelery_app.pyファイルがある -

from __future__ import absolute_import 
import os 
from celery import Celery 
from django.conf import settings 

# set the default Django settings module for the 'celery' program. 
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project.settings') 

app = Celery(broker=settings.CELERY_BROKER_URL) 
app.config_from_object('django.conf:settings') 
app.autodiscover_tasks() 

if __name__ == '__main__': 
    app.start() 

私tasks.pyファイルではあるが -

from project.celery_app import app 

@app.task 
def mytask(): 
    ... 

私はターミナルでセロリを実行する上で、以下の出力を得る -

-------------- [email protected] v4.1.0 (latentcall) 
---- **** ----- 
--- * *** * -- Windows-10-10.0.16299-SP0 2017-12-20 19:27:24 
-- * - **** --- 
- ** ---------- [config] 
- ** ---------- .> app:   __main__:0x229ce2884e0 
- ** ---------- .> transport: amqp://user:**@localhost:5672/myvhost 
- ** ---------- .> results:  disabled:// 
- *** --- * --- .> concurrency: 8 (solo) 
-- ******* ---- .> task events: OFF (enable -E to monitor tasks in this   worker) 
--- ***** ----- 
-------------- [queues] 
       .> celery   exchange=celery(direct) key=celery 


[tasks] 
    . account.tasks.mytask 

[2017-12-20 19:27:24,085: INFO/MainProcess] Connected to  amqp://user:**@127.0.0.1:5672/myvhost 
[2017-12-20 19:27:24,101: INFO/MainProcess] mingle: searching for neighbors 
[2017-12-20 19:27:25,126: INFO/MainProcess] mingle: all alone 
[2017-12-20 19:27:25,141: WARNING/MainProcess]  c:\programdata\anaconda2\envs\myenv\lib\site- packages\celery\fixups\django.py:202: UserWarning: Using settings.DEBUG leads to  a memory leak, never use this setting in production environments! 
    warnings.warn('Using settings.DEBUG leads to a memory leak, never ' 
[2017-12-20 19:27:25,141: INFO/MainProcess] [email protected] ready. 

私の仕事はセロリに知られていますが、それについては何もしません。タスクはボタンクリックで実行され、-loglevel = debugを使用すると、セロリに影響されないことがわかります。私はブローカー、セロリ4.1.0、python3とdjango - 1.10.5としてRabbitMQを使用しています。どんな助けでも大歓迎です!

答えて

1

私が思ったように、単純な間違いです。 mytask()mytask.delay()に変更してセロリーを受け取るだけでした。

関連する問題