Python 皮卡,停止消费不行
我是rabbitmq和pika的新手,在停止消费方面遇到了困难 通道和队列设置:Python 皮卡,停止消费不行,python,rabbitmq,pika,Python,Rabbitmq,Pika,我是rabbitmq和pika的新手,在停止消费方面遇到了困难 通道和队列设置: connection = pika.BlockingConnection(pika.ConnectionParameters('localhost')) channel = connection.channel() channel.queue_declare(queue=new_task_id, durable=True, auto_delete=True) 基本上,消费者和生产者是这样的: 消费者: def t
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”
没有打印出来,所以我猜这是因为频道。停止消费(任务id)
没有停止消费。如果是,正确的方法是什么?谢谢。我也有同样的问题。这似乎是由以下事实引起的:start\u consuming
调用self.connection.process\u data\u事件(time\u limit=None)
。此时间限制=None
使其挂起
我设法解决了这个问题,用它的实现替换了对channel.start\u consuming()
的调用,hacked:
while channel._consumer_infos:
channel.connection.process_data_events(time_limit=1) # 1 second
你确定停止消费会被呼叫吗?@eandersson是的,我确定。好的。您确定传递了正确的ID以停止消费吗?试着简单地使用
频道。停止消费()
我现在没有条件证明你的答案,无论如何,我会接受的。shx2,我想你是对的。至少,通过查看源代码,我也理解了这一点。而且它似乎也解决了这个问题。我要开一张票。