2013-03-09 3 views
5

分散タスクのためにRabbitMQと会話しているdjango-seleryを使ってDebianサーバーにDjangoのインスタンスを設定しようとしています。RabbitMQでDjango-Celeryを起動して致命的なエラーが発生する[未知のAMQPメソッド(10,60)]

私はRabbitMQサーバーをセットアップすることができますが、それは良い状態で応答しますが、セロリがRabbitMQと接触するとすぐにエラーを投げてシャットダウンします。私はセロリのDEVのインスタンスを起動しようとすると、それがどのように見えるかをここにあります:

[2013-03-08 16:59:23,707: WARNING/MainProcess] [email protected] ready. 
[2013-03-08 16:59:23,725: INFO/MainProcess] consumer: Connected to amqp://[email protected]:5672//rabbit_vhost. 
[2013-03-08 16:59:23,734: ERROR/MainProcess] Unrecoverable error: AMQPError('Unknown AMQP method (10, 60)', None, None, None, '') 
Traceback (most recent call last): 
    File "/usr/local/lib/python2.6/dist-packages/celery/worker/__init__.py", line 351, in start 
    component.start() 
    File "/usr/local/lib/python2.6/dist-packages/celery/worker/consumer.py", line 392, in start 
    self.reset_connection() 
    File "/usr/local/lib/python2.6/dist-packages/celery/worker/consumer.py", line 748, in reset_connection 
    self.reset_pidbox_node() 
    File "/usr/local/lib/python2.6/dist-packages/celery/worker/consumer.py", line 687, in reset_pidbox_node 
    callback=self.on_control, 
    File "/usr/local/lib/python2.6/dist-packages/kombu/pidbox.py", line 71, in listen 
    consumer.consume() 
    File "/usr/local/lib/python2.6/dist-packages/kombu/messaging.py", line 401, in consume 
    self._basic_consume(T, no_ack=no_ack, nowait=False) 
    File "/usr/local/lib/python2.6/dist-packages/kombu/messaging.py", line 522, in _basic_consume 
    no_ack=no_ack, nowait=nowait) 
    File "/usr/local/lib/python2.6/dist-packages/kombu/entity.py", line 571, in consume 
    nowait=nowait) 
    File "/usr/local/lib/python2.6/dist-packages/amqp/channel.py", line 1766, in basic_consume 
    (60, 21), # Channel.basic_consume_ok 
    File "/usr/local/lib/python2.6/dist-packages/amqp/abstract_channel.py", line 69, in wait 
    self.channel_id, allowed_methods) 
    File "/usr/local/lib/python2.6/dist-packages/amqp/connection.py", line 230, in _wait_method 
    self.wait() 
    File "/usr/local/lib/python2.6/dist-packages/amqp/abstract_channel.py", line 71, in wait 
    return self.dispatch_method(method_sig, args, content) 
    File "/usr/local/lib/python2.6/dist-packages/amqp/abstract_channel.py", line 85, in dispatch_method 
    raise AMQPError('Unknown AMQP method %r' % (method_sig,)) 
AMQPError: Unknown AMQP method (10, 60) 

だけを確認するために、私はRabbitMQのはまだ後で実行されていることを確認することができます。

# rabbitmqctl status 
Status of node [email protected] ... 
[{running_applications,[{rabbit,"RabbitMQ","1.8.1"}, 
         {mnesia,"MNESIA CXC 138 12","4.4.14"}, 
         {os_mon,"CPO CXC 138 46","2.2.5"}, 
         {sasl,"SASL CXC 138 11","2.1.9.2"}, 
         {stdlib,"ERTS CXC 138 10","1.17"}, 
         {kernel,"ERTS CXC 138 10","2.14"}]}, 
{nodes,[{disc,[[email protected]]}]}, 
{running_nodes,[[email protected]]}] 
...done. 

これは防ぐ最後の事です私は自分のサイトを立ち上げるのを止めて、私はすべて悩んでしまったので、どんな助けでも大歓迎です!ありがとう。

答えて

6

kombuを2.4.7にダウングレードすると修正されます。 rabbitmq-serverは、AMQP 0-9-1をサポートするのに十分な新しいものではありません。

+0

ありがとうございます!これらの人は同じ問題を抱えているようです:[github issue](https://github.com/celery/django-celery/issues/217) – Lou

1

Ubuntuで同じ問題が発生しました。 (おそらくUbuntuのバージョンによっては)付属のRabbitMQパッケージが古くなっているようです。 RabbitMQ installation guideにはこれが可能であると記載されています。したがって、Webサイトから.debパッケージをインストールすることをお勧めします。

関連する問題