相关疑难解决方法(0)

RabbitMQ/Celery与Django挂起延迟/准备/等 - 没有有用的日志信息

所以我只是设置celery和rabbitmq,创建我的用户,设置vhost,将用户映射到vhost,并成功运行celery守护进程(或者我假设)

(queuetest)corky@corky-server:~/projects/queuetest$ ./manage.py celeryd
 celery@corky-server v0.9.5 is starting.
 Configuration ->
. broker -> amqp://celery@localhost:5672/
. queues ->
. celery -> exchange:celery (direct) binding:celery
. concurrency -> 2
. loader -> celery.loaders.djangoapp
. logfile -> [stderr]@WARNING
. events -> OFF
. beat -> OFF

Celery has started.
Run Code Online (Sandbox Code Playgroud)

我创造了一个"芹菜"的用户,因为在这种情况下我并没有感觉很有创造力.

当我尝试在芹菜文档中做一个简单的例子时:

>>> from tasks import add
>>> r = add.delay(2, 2)
>>> r
<AsyncResult: 16235ea3-c7d6-4cce-9387-5c6285312c7c>
>>> r.ready()
(hangs for eternity.)
Run Code Online (Sandbox Code Playgroud)

所以我检查了常见问题解答,想知道还有什么可能会起来,它告诉我这是一个由于用户权限而导致的常见错误,所以我三重检查那些,没有,做了另一个新用户,仍然没有.如果我DjangoBrokerConnection从中导入carrot.connection并获取信息,它会与我的芹菜设置中的内容相匹配.常见问题解答说明了检查您的日志文件.

我的rabbit.log文件在这种情况下不是很有用,只是显示:

=INFO REPORT==== 26-Jan-2010::11:58:22 ===
accepted …
Run Code Online (Sandbox Code Playgroud)

python django rabbitmq celery

6
推荐指数
1
解决办法
2358
查看次数

在 Django 中调用 .delay() 后 Celery 任务挂起

.delay()从 django 应用程序调用导入任务的方法时,进程卡住并且请求从未完成。

我们也没有在控制台上收到任何错误。set_trace()使用 pdb设置 a 会导致相同的结果。

审查了以下问题,但无助于解决问题:

调用 celery 任务因延迟和 apply_async 而挂起

celery .delay 挂起(最近,不是身份验证问题)

例如。:

后端/settings.py

CELERY_BROKER_URL = os.environ.get("CELERY_BROKER", RABBIT_URL)
CELERY_RESULT_BACKEND = os.environ.get("CELERY_BROKER", RABBIT_URL)
Run Code Online (Sandbox Code Playgroud)

后端/芹菜.py

from __future__ import absolute_import, unicode_literals

import os

from celery import Celery

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

app = Celery('backend')

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))
Run Code Online (Sandbox Code Playgroud)

应用程序/任务.py

import time
from celery …
Run Code Online (Sandbox Code Playgroud)

python django celery

6
推荐指数
1
解决办法
1037
查看次数

标签 统计

celery ×2

django ×2

python ×2

rabbitmq ×1