22

我在 Python 中使用 Kombu 来使用持久的 RabbitMQ 队列。

在 Windows 中只有一个消费者在消费队列。此消费者产生以下错误:

Traceback (most recent call last):
  File ".\consumer_windows.py", line 66, in <module>
    message.ack()
  File "C:\Users\Administrator\Anaconda2\lib\site-packages\kombu\message.py", line 88, in ack
    self.channel.basic_ack(self.delivery_tag)
  File "C:\Users\Administrator\Anaconda2\lib\site-packages\amqp\channel.py", line 1584, in basic_ack
    self._send_method((60, 80), args)
  File "C:\Users\Administrator\Anaconda2\lib\site-packages\amqp\abstract_channel.py", line 56, in _send_method
    self.channel_id, method_sig, args, content,
  File "C:\Users\Administrator\Anaconda2\lib\site-packages\amqp\method_framing.py", line 221, in write_method
    write_frame(1, channel, payload)
  File "C:\Users\Administrator\Anaconda2\lib\site-packages\amqp\transport.py", line 182, in write_frame
    frame_type, channel, size, payload, 0xce,
  File "C:\Users\Administrator\Anaconda2\lib\socket.py", line 228, in meth
    return getattr(self._sock,name)(*args)
error: [Errno 10054] An existing connection was forcibly closed by the remote host

任何时候队列中最多有 500 条消息。每条消息都很小,但它是一项任务,最多需要 10 分钟才能完成(尽管每条消息通常需要不到 5 分钟)。

我尝试重新启动消费者、RabbitMQ 服务器并删除队列,但错误仍然存​​在。

我见过这个问题,但是答案来自 2010 年,我的 rabbitmq.log 有不同的条目:

=ERROR REPORT==== 24-Apr-2016::08:26:20 ===
closing AMQP connection <0.6716.384> (192.168.X.X:59602 -> 192.168.Y.X:5672):
{writer,send_failed,{error,timeout}}

rabbitmq-sasl.log 中没有最近的事件。

为什么会发生此错误,我该如何防止它发生?

4

2 回答 2

1

我还在寻找答案。与此同时,我重新启动了与我的 rabbit 服务器的连接:

while True:
    try:
​
        connection = pika.BlockingConnection(params)
        channel = connection.channel() # start a channel
        channel.queue_declare(queue=amqp_q, durable=True) # Declare a queue
        ...
​
    except pika.exceptions.ConnectionClosed:
        print('connection closed... and restarted')
于 2020-03-31T17:40:27.400 回答
0

我在托管的 MySQL 服务器上遇到了同样的问题...我了解到,如果我们长时间打开连接或长时间未修改,就会发生这种情况。如果您的程序打开数据库或其他任何东西,直到整个程序运行使其以这样一种方式打开数据库写入所有内容并关闭并重复

我不知道rabbitmq到底是什么,但我认为你写为标题的错误可能是因为这个原因

于 2019-02-27T00:49:56.987 回答