5

我的 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>

在课堂上,我用

private static readonly ILog Log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);

并调用 Log.Error(message); 只有一次,但在我的日志中,所有错误都是重复的。此外,此方法在 WebApi 项目的控制器类中被调用。

我已经阅读了其他问题,当使用多个记录器并且它们将消息传播到根记录器时可能会发生这种情况,但是,在这种情况下我只使用根记录器。

4

1 回答 1

5

似乎问题出在 AWS 开发工具包特定的配置上:

     <add key="AWSLogging" value="log4net" />

不知何故,这重复了附加程序并导致了双重消息。

要修复,只需删除此设置或将值更改为“无”。

于 2016-12-11T14:07:49.507 回答