仅使用一个(根)记录器时的 Log4net 重复条目
Log4net duplicate entries when only one (root) logger is used
我的 log4net 配置如下所示:
<log4net>
<appender name="CloudWatchLogsAppender" type="CloudWatchAppender.CloudWatchLogsAppender, CloudWatchAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %level %logger.%method - %message%newline" />
</layout>
<groupName value="agroupname" />
<streamName value="astreamname" />
</appender>
<root>
<level value="INFO" />
<appender-ref ref="CloudWatchLogsAppender" />
</root>
<logger name="Amazon">
<level value="OFF" />
</logger>
</log4net>
在 classes 中,我用
实例化了记录器
private static readonly ILog Log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
并调用Log.Error(message);只有一次,但在我的日志中,所有错误都是重复的。此外,正在 WebApi 项目的控制器 class 中调用此方法。
我在其他问题中读到,当使用多个记录器并将消息传播到根记录器时可能会发生这种情况,但是,在这种情况下我只使用根记录器。
问题似乎出在 AWS SDK 特定配置上:
<add key="AWSLogging" value="log4net" />
不知何故,这复制了附加程序并导致了双重消息。
要修复,只需删除此设置或将值更改为 "none"。
我的 log4net 配置如下所示:
<log4net>
<appender name="CloudWatchLogsAppender" type="CloudWatchAppender.CloudWatchLogsAppender, CloudWatchAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %level %logger.%method - %message%newline" />
</layout>
<groupName value="agroupname" />
<streamName value="astreamname" />
</appender>
<root>
<level value="INFO" />
<appender-ref ref="CloudWatchLogsAppender" />
</root>
<logger name="Amazon">
<level value="OFF" />
</logger>
</log4net>
在 classes 中,我用
实例化了记录器private static readonly ILog Log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
并调用Log.Error(message);只有一次,但在我的日志中,所有错误都是重复的。此外,正在 WebApi 项目的控制器 class 中调用此方法。
我在其他问题中读到,当使用多个记录器并将消息传播到根记录器时可能会发生这种情况,但是,在这种情况下我只使用根记录器。
问题似乎出在 AWS SDK 特定配置上:
<add key="AWSLogging" value="log4net" />
不知何故,这复制了附加程序并导致了双重消息。
要修复,只需删除此设置或将值更改为 "none"。