为Pika ioloop异步设置超时(RabbitMQ)

时间:2011-11-18 09:56:09

标签: python rabbitmq pika

我需要能够优雅地阻止在Pika ioloop工作的消费者(工人)。工人应该在60秒后停止。当前处理的消息应该完成。

我试图在回调函数中添加connection.close(),但这只停止了当前线程而不是完整的ioloop。它给出了一个可怕的错误输出。

请参阅我的代码中的第16行及其后续内容:我使用了(关于Pika ioloop http://pika.github.com/connecting.html#cps-example的基本示例:

    from pika.adapters import SelectConnection
    channel = None
    def on_connected(connection):
        connection.channel(on_channel_open)

    def on_channel_open(new_channel):
        global channel
        channel = new_channel
        channel.queue_declare(queue="test", durable=True, exclusive=False, auto_delete=False, callback=on_queue_declared)

    def on_queue_declared(frame):
        channel.basic_consume(handle_delivery, queue='test')

    def handle_delivery(channel, method, header, body):
        print body

        # timer stuff which did NOT work
        global start_time, timeout, connection
        time_diff = time.time()-start_time
        if time_diff > timeout:
            #raise KeyboardInterrupt
            connection.close()

    timeout = 60
    start_time = time.time()

    connection = SelectConnection(parameters, on_connected)

    try:
        connection.ioloop.start()
    except KeyboardInterrupt:
        connection.close()
        connection.ioloop.start()

2 个答案:

答案 0 :(得分:9)

您可以在打开的连接上附加超时回叫功能。 以下是您的示例的额外代码。

timeout = 60

def on_timeout():
  global connection
  connection.close()

connection.add_timeout(timeout, on_timeout)

答案 1 :(得分:-4)

您可以尝试使用:

connection.ioloop.stop()