Mark van Renswoude
2e2a77a7ae
- Consume calls still in the TapetiClient task queue while it is reconnecting would not be cancelled, but new calls were added as well after the reconnect - Unrelated but useful: added LocalPort and Disconnect event to logging
95 lines
3.6 KiB
C#
95 lines
3.6 KiB
C#
using System;
|
|
using Tapeti.Config;
|
|
using ISerilogLogger = Serilog.ILogger;
|
|
|
|
// ReSharper disable UnusedMember.Global
|
|
|
|
namespace Tapeti.Serilog
|
|
{
|
|
/// <inheritdoc />
|
|
/// <summary>
|
|
/// Implements the Tapeti ILogger interface for Serilog output.
|
|
/// </summary>
|
|
public class TapetiSeriLogger: ILogger
|
|
{
|
|
private readonly ISerilogLogger seriLogger;
|
|
|
|
|
|
/// <inheritdoc />
|
|
public TapetiSeriLogger(ISerilogLogger seriLogger)
|
|
{
|
|
this.seriLogger = seriLogger;
|
|
}
|
|
|
|
|
|
/// <inheritdoc />
|
|
public void Connect(IConnectContext connectContext)
|
|
{
|
|
seriLogger
|
|
.ForContext("isReconnect", connectContext.IsReconnect)
|
|
.Information("Tapeti: trying to connect to {host}:{port}/{virtualHost}",
|
|
connectContext.ConnectionParams.HostName,
|
|
connectContext.ConnectionParams.Port,
|
|
connectContext.ConnectionParams.VirtualHost);
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void ConnectFailed(IConnectFailedContext connectContext)
|
|
{
|
|
seriLogger.Error(connectContext.Exception, "Tapeti: could not connect to {host}:{port}/{virtualHost}",
|
|
connectContext.ConnectionParams.HostName,
|
|
connectContext.ConnectionParams.Port,
|
|
connectContext.ConnectionParams.VirtualHost);
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void ConnectSuccess(IConnectSuccessContext connectContext)
|
|
{
|
|
seriLogger
|
|
.ForContext("isReconnect", connectContext.IsReconnect)
|
|
.Information("Tapeti: successfully connected to {host}:{port}/{virtualHost} on local port {localPort}",
|
|
connectContext.ConnectionParams.HostName,
|
|
connectContext.ConnectionParams.Port,
|
|
connectContext.ConnectionParams.VirtualHost,
|
|
connectContext.LocalPort);
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void Disconnect(IDisconnectContext disconnectContext)
|
|
{
|
|
seriLogger
|
|
.Information("Tapeti: connection closed, reply text = {replyText}, reply code = {replyCode}",
|
|
disconnectContext.ReplyText,
|
|
disconnectContext.ReplyCode);
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void ConsumeException(Exception exception, IMessageContext messageContext, ConsumeResult consumeResult)
|
|
{
|
|
var contextLogger = seriLogger
|
|
.ForContext("consumeResult", consumeResult)
|
|
.ForContext("exchange", messageContext.Exchange)
|
|
.ForContext("queue", messageContext.Queue)
|
|
.ForContext("routingKey", messageContext.RoutingKey);
|
|
|
|
if (messageContext is IControllerMessageContext controllerMessageContext)
|
|
{
|
|
contextLogger = contextLogger
|
|
.ForContext("controller", controllerMessageContext.Binding.Controller.FullName)
|
|
.ForContext("method", controllerMessageContext.Binding.Method.Name);
|
|
}
|
|
|
|
contextLogger.Error(exception, "Tapeti: exception in message handler");
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void QueueObsolete(string queueName, bool deleted, uint messageCount)
|
|
{
|
|
if (deleted)
|
|
seriLogger.Information("Tapeti: obsolete queue {queue} has been deleted", queueName);
|
|
else
|
|
seriLogger.Information("Tapeti: obsolete queue {queue} has been unbound but not yet deleted, {messageCount} messages remaining", queueName, messageCount);
|
|
}
|
|
}
|
|
}
|