0

タイムアウトを設定したいrabbitmqサーバーから受信するクライアントプログラムを作成しようとしています。指定された時間が経過すると、クライアントはキューからのメッセージの消費を停止して終了する必要があります。

Blocking connection でピカを使用しています。ブロッキング接続で add_timeout(delay,callback) が定義されているのを見ましたが、それを使用しようとすると、次のようなエラーが発生します。

 [*] Waiting for logs. To exit press CTRL+C
Traceback (most recent call last):
  File "/root/workspace/Misc/misc/pika_samples/log_recieve.py", line 39, in <module>
    channel.start_consuming()
  File "/usr/lib/python2.6/site-packages/pika/adapters/blocking_connection.py", line 293, in start_consuming
    self.transport.connection.process_data_events()
  File "/usr/lib/python2.6/site-packages/pika/adapters/blocking_connection.py", line 103, in process_data_events
    self.process_timeouts()
  File "/usr/lib/python2.6/site-packages/pika/adapters/blocking_connection.py", line 160, in process_timeouts
    self._timeouts[timeout_id]['handler']()
TypeError: callback() takes exactly 4 arguments (0 given)

これは私のクライアント プログラムです。タイムアウト条件をシミュレートするためにサーバーを実行していません。

#!/usr/bin/env python
import pika
import sys

connection = pika.BlockingConnection(pika.ConnectionParameters(host='localhost'))
channel = connection.channel()
channel.exchange_declare(exchange='topic_logs',type='topic')
result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue
binding_keys = "#"
for binding_key in binding_keys:
    channel.queue_bind(exchange='topic_logs',queue=queue_name,
                   routing_key=binding_key)

print ' [*] Waiting for logs. To exit press CTRL+C'
def callback(ch, method, properties, body):
    print " [x] %r:%r" % (method.routing_key, body,)
    channel.stop_consuming()
connection.add_timeout(10, callback)
channel.basic_consume(callback,queue=queue_name,no_ack=True)
channel.start_consuming()

指定されたタイムアウト期間内にメッセージを取得すると、クライアントはメッセージを出力することになり、それ以上の消費を停止する必要があります。

クライアントでタイムアウトを設定する方法を教えてもらえますか?

4

1 に答える 1

0

この問題は期限内です。次に、引数なしで呼び出される関数コールバックが発生します。だからあなたはあなたのコードを変更することができます

def callback(ch=None, method=None, properties=None, body=None):
    if ch is None or method is None or properties is None or body is None:
         print "Deadline"
    else:
         print " [x] %r:%r" % (method.routing_key, body,)
于 2012-04-27T14:10:35.783 に答える