皮卡,别再吃了

2024-05-13 08:24:44 发布

您现在位置:Python中文网/ 问答频道 /正文

我对拉比马克和皮卡还不熟悉,所以很难停止消费。

通道和队列设置:

connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
channel.queue_declare(queue=new_task_id, durable=True, auto_delete=True)

基本上,消费者和生产者是这样的:

消费者:

def task(task_id):
    def callback(channel, method, properties, body):
        if body != "quit":
            print(body)
        else:
            print(body)
            channel.stop_consuming(task_id)

    channel.basic_consume(callback, queue=task_id, no_ack=True)
    channel.start_consuming()
    print("finish")
    return "finish"

制作人:

proc = Popen(['app/sample.sh'], shell=True, stdout=PIPE)
while proc.returncode is None:  # running
    line = proc.stdout.readline()
    if line:
        channel.basic_publish(
            exchange='',
            routing_key=self.request.id,
            body=line
        )
    else:
        channel.basic_publish(
            exchange='',
            routing_key=self.request.id,
            body="quit"
        )
        break

消费者task给了我输出:

# ... output from sample.sh, as expected

quit
�}q(UstatusqUSUCCESSqU  tracebackqNUresultqNUtask_idqU
1419350416qUchildrenq]u.

但是,"finish"没有打印出来,所以我猜是因为channel.stop_consuming(task_id)没有停止消费。如果是,正确的方法是什么?谢谢您。


Tags: idtruetaskbasicqueuelinechannel消费者
1条回答
网友
1楼 · 发布于 2024-05-13 08:24:44

我也有同样的问题。这似乎是由于在内部,start_consuming调用self.connection.process_data_events(time_limit=None)造成的。这个time_limit=None使它挂起。

我设法解决了这个问题,用它的实现替换了对channel.start_consuming()的调用,hacked:

while channel._consumer_infos:
    channel.connection.process_data_events(time_limit=1) # 1 second

相关问题 更多 >