4

我需要能够优雅地停止在 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()
4

2 回答 2

10

您可以在打开的连接上附加超时回调函数。这是您的示例的额外代码。

timeout = 60

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

connection.add_timeout(timeout, on_timeout)
于 2011-11-18T10:32:52.417 回答
-4

您可以尝试使用:

connection.ioloop.stop()
于 2011-12-07T06:11:10.590 回答