19

我正在使用 log4net 进行日志记录。我希望它同时写入文件和事件日志。

出于某种原因,我在日志文件中找到了两次消息。

这是我的 app.config-section :

<log4net>
    <root>
        <level value="INFO" />
        <appender-ref ref="LogFileAppender" />
        <appender-ref ref="EventLogAppender" />
    </root>
    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" >
        <param name="File" value="c:\temp\DIS-logfile.txt" />
        <param name="AppendToFile" value="true" />
        <rollingStyle value="Size" />
        <maxSizeRollBackups value="10" />
        <maximumFileSize value="10MB" />
        <staticLogFileName value="true" />
        <layout type="log4net.Layout.PatternLayout">
            <param name="ConversionPattern" value="%date %-5level %logger - %message%newline" />
        </layout>
    </appender>
    <appender name="EventLogAppender" type="log4net.Appender.EventLogAppender">
        <param name="Indigo.DataIntakeService" value="eventlog" />
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date %-5level %logger - %message%newline" />
            </layout>
    </appender>
</log4net>

在我的代码中,我有以下内容:

private static readonly ILog Log = log4net.LogManager.GetLogger("DataIntakeService");
private static readonly ILog LogEvents = log4net.LogManager.GetLogger("EventLogAppender");

static void Main(string[] args)
{
    log4net.Config.XmlConfigurator.Configure();
}

public static void LogInfo(string message)
{
    Log.Info(message);
    LogEvents.Info(message);
}

它会按要求写入我的日志文件,但消息也应该发送到我的事件查看器,但不会发生这种情况。它还将这些消息写入日志文件。

我哪里做错了?

4

2 回答 2

33

您已配置 Log4Net,以便根记录器记录到文件和事件日志附加程序。所有记录器都继承此配置,因此您的记录器“DataIntakeService”和“EventLogAppender”都记录到这些附加程序。

如果您在事件查看器中没有看到日志消息,可能是因为您的应用程序没有创建事件源的权限。

更新

我该如何配置它,以便 DataIntakeService 记录到文件,另一个记录到 eventviewer?

这是一个示例配置:

<log4net>
  <root>
    <level value="INFO" />
    <appender-ref ref="LogFileAppender" />
  </root>
  <logger name="EventLogAppender" additivity="False">
    <level value="INFO" />
    <appender-ref ref="EventLogAppender" />
  </logger>
  <appender>
  ... 

使用此示例:

  • 根记录器(以及所有子记录器,除非另有明确配置)将记录到LogFileAppender. 您的DataIntakeService记录器未明确配置,因此继承此配置。

  • 记录器EventLogAppender显式配置为记录到EventLogAppender,并且配置为不从父记录器 ( additivity="false") 继承设置。因此它不会登录到LogFileAppender. 如果您设置additivity="true"它将继承设置并同时记录到LogFileAppenderEventLogAppender

顺便说一句,命名记录器EventLogAppender可能有点令人困惑:EventLogLogger可能是一个更好的名称。

于 2013-06-14T10:44:45.927 回答
12

您可以通过以下配置使用 log4net 写入不同的记录器。

<log4net>
<logger name="LogFileLogger">
  <level value="INFO" />
  <appender-ref ref="LogFileAppender" />
</logger>
<logger name="EventLogger">
  <level value="INFO" />
  <appender-ref ref="EventLogAppender" />
</logger>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
  ...
</appender>
<appender name="EventLogAppender" type="log4net.Appender.EventLogAppender">
  ...
</appender>

您可以将记录器称为:

private static readonly log4net.ILog LogFileLogger= log4net.LogManager.GetLogger("LogFileLogger");
private static readonly log4net.ILog EventLogger= log4net.LogManager.GetLogger("EventLogger");
于 2017-03-28T16:21:16.510 回答