RabbitMQ - обновлен до новой версии и получил много «PRECONDITION_FAILED неизвестный тег доставки 1»

Только что обновился до новой версии RabbitMQ - 2.3. 1 - и теперь возникает следующая ошибка:

PRECONDITION_FAILED unknown delivery tag 1  

... с последующим закрытием канала. Это работало на более старом RabbitMQ без изменений на стороне клиента.


С точки зрения поведения приложения:

Когда приложение A хочет отправить асинхронное сообщение в приложение b и получить ответ от B, это алгоритм:

  1. Приложение A генерирует уникальный идентификатор и помещает его в объект сообщения
  2. Затем приложение A подписывается на новую очередь с именем очереди и ключом маршрутизации, равными uuid.
  3. Приложение B открывает сообщение, выполните некоторые вычисления и вернуть результат в канал с полученным ключом маршрутизации.
  4. Приложение A получает ответ и закрывает очередь.

До сих пор все шло хорошо в 1.7.0. что пошло не так в 2.3.1?


Когда приложение A вызывает basicPublish () , приложение B немедленно выдает следующее исключение:

com.rabbitmq.client.ShutdownSignalException: channel error; reason: {#method<channel.close>(reply-code=406,reply-text=PRECONDITION_FAILED - unknown delivery tag 1,class-id=60,method-id=80),null,""}
    at com.rabbitmq.client.impl.ChannelN.processAsync(ChannelN.java:191)
    at com.rabbitmq.client.impl.AMQChannel.handleCompleteInboundCommand(AMQChannel.java:159)
    at com.rabbitmq.client.impl.AMQChannel.handleFrame(AMQChannel.java:110)
    at com.rabbitmq.client.impl.AMQConnection$MainLoop.run(AMQConnection.java:438)
Caused by: com.rabbitmq.client.ShutdownSignalException: channel error; reason: {#method<channel.close>(reply-code=406,reply-text=PRECONDITION_FAILED - unknown delivery tag 1,class-id=60,method-id=80),null,""}
16
задан Charles Duffy 4 September 2012 в 16:07
поделиться