2012-02-24 81 views
2

我在运行任务时遇到问题。我运行./manage celeryd -B -l info,它正确地加载到注册表的所有任务。django-celery或python的奇怪错误

错误发生在任何任务运行 - 在任务开始,做它的东西,然后我得到:

[ERROR/MainProcess] Thread 'ResultHandler' crashed: ValueError('Octet out of range 0..2**64-1',) 
Traceback (most recent call last): 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/concurrency/processes/pool.py", line 221, in run 
    return self.body() 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/concurrency/processes/pool.py", line 458, in body 
    on_state_change(task) 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/concurrency/processes/pool.py", line 436, in on_state_change 
    state_handlers[state](*args) 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/concurrency/processes/pool.py", line 413, in on_ack 
    cache[job]._ack(i, time_accepted, pid) 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/concurrency/processes/pool.py", line 1016, in _ack 
    self._accept_callback(pid, time_accepted) 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/worker/job.py", line 424, in on_accepted 
    self.acknowledge() 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/worker/job.py", line 516, in acknowledge 
    self.on_ack() 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/celery/worker/consumer.py", line 405, in ack 
    message.ack() 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/kombu-2.1.0-py2.7.egg/kombu/transport/base.py", line 98, in ack 
    self.channel.basic_ack(self.delivery_tag) 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/amqplib-1.0.2-py2.7.egg/amqplib/client_0_8/channel.py", line 1740, in basic_ack 
    args.write_longlong(delivery_tag) 
    File "/Users/jzelez/Sites/my_virtual_env/lib/python2.7/site-packages/amqplib-1.0.2-py2.7.egg/amqplib/client_0_8/serialization.py", line 325, in write_longlong 
    raise ValueError('Octet out of range 0..2**64-1') 
ValueError: Octet out of range 0..2**64-1 

我也必须指出,这个工作我以前的狮子安装,即使我用一些测试代码创建了一个空白的virtualenv,当一个任务运行时它给出了这个错误。

这发生在Python 2.7.2和2.6.4上。

Django==1.3.1 
amqplib==1.0.2 
celery==2.4.6 
django-celery==2.4.2 
+0

什么是delivery_tag?使用pdb.pm()进入堆栈跟踪并找出。 – Marcin 2012-02-24 13:17:52

回答

0

它似乎有一些与自制安装蟒蛇的错误。我现在切换到本地狮子(2.7.1),它的工作原理。

+1

另外你可以升级到Python 2.7.3来解决这个问题。 – okm 2012-05-08 00:53:04