Есть ли у вас указатели, как определить, когда возникла проблема с подпиской, чтобы я мог повторно подключиться?
Моя служба использует RabbitMQ.Client.MessagePatterns.Subscription для подписки. Через некоторое время мой клиент молча перестает получать сообщения. Я подозреваю, что проблемы с сетью связаны с тем, что мое VPN-соединение не является самым надежным.
Я прочитал документы за некоторое время, ища ключ, чтобы узнать, когда эта подписка может быть нарушена из-за сетевой проблемы без большой удачи. Я попытался проверить, что соединение и канал все еще открыты, но он всегда, кажется, сообщает, что он все еще открыт.
Сообщения, которые он обрабатывает, работают достаточно хорошо и подтверждаются обратно в очередь, поэтому я не думаю, что это проблема с "ack".
Я уверен, что я просто пропустил что-то простое, но я еще не нашел его.
public void Run(string brokerUri, Action<byte[]> handler)
{
log.Debug("Connecting to broker: {0}".Fill(brokerUri));
ConnectionFactory factory = new ConnectionFactory { Uri = brokerUri };
using (IConnection connection = factory.CreateConnection())
{
using (IModel channel = connection.CreateModel())
{
channel.QueueDeclare(queueName, true, false, false, null);
using (Subscription subscription = new Subscription(channel, queueName, false))
{
while (!Cancelled)
{
BasicDeliverEventArgs args;
if (!channel.IsOpen)
{
log.Error("The channel is no longer open, but we are still trying to process messages.");
throw new InvalidOperationException("Channel is closed.");
}
else if (!connection.IsOpen)
{
log.Error("The connection is no longer open, but we are still trying to process message.");
throw new InvalidOperationException("Connection is closed.");
}
bool gotMessage = subscription.Next(250, out args);
if (gotMessage)
{
log.Debug("Received message");
try
{
handler(args.Body);
}
catch (Exception e)
{
log.Debug("Exception caught while processing message. Will be bubbled up.", e);
throw;
}
log.Debug("Acknowledging message completion");
subscription.Ack(args);
}
}
}
}
}
}
UPDATE:
Я смоделировал сетевой сбой, запустив сервер на виртуальной машине, и я получаю исключение (RabbitMQ.Client.Exceptions.OperationInterruptedException: операция AMQP была прервана), когда я прерываю соединение достаточно долго, поэтому, возможно, t проблема сети. Теперь я не знаю, что бы это было, но это не удалось через пару часов работы.