Jestem nowy dla rabbitmq i pika i mam problem z zatrzymaniem konsumpcji.pika, stop_consuming nie działa
kanał kolejek ustawienie:
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
channel.queue_declare(queue=new_task_id, durable=True, auto_delete=True)
Zasadniczo konsumentów i producentów, są jak poniżej:
konsumenta:
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"
producent:
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
konsument task
dała mi wynik:
# ... output from sample.sh, as expected
quit
�}q(UstatusqUSUCCESSqU tracebackqNUresultqNUtask_idqU
1419350416qUchildrenq]u.
Jednak "finish"
nie wydrukowany, więc zgaduję, że to dlatego channel.stop_consuming(task_id)
nie powstrzymało czasochłonne. Jeśli tak, jaki jest właściwy sposób postępowania? Dziękuję Ci.
Czy jesteś pewien, że stop_consuming pobiera nazywane? – eandersson
@eandersson Tak, jestem pewien. – laike9m
Ok. Czy jesteś pewien, że podajesz prawidłowy identyfikator do stop_consuming? Spróbuj po prostu użyć '' 'channel.stop_consuming()' '' – eandersson