Использование log4net для записи в разные регистраторы - программирование
Подтвердить что ты не робот

Использование log4net для записи в разные регистраторы

Я использую log4net для ведения журнала. Мне бы хотелось, чтобы он одновременно записывал файлы и журнал событий.

По какой-то причине я дважды нахожу сообщения в своем лог файле.

Это мой раздел app.config:

<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);
}

Он записывает в мой лог файл, как и было запрошено, но сообщения также должны отправляться моему наблюдателю, и этого не происходит. Эти сообщения также записываются в файл журнала.

Где я неправ?

4b9b3361

Ответ 1

Вы настроили Log4Net так, чтобы корневой журнал регистрировался как в файлах, так и в файлах событий. Все регистраторы наследуют эту конфигурацию, поэтому оба регистратора "DataIntakeService" и "EventLogAppender" регистрируются в этих добавках.

Если вы не видите сообщения журнала в средстве просмотра событий, это может быть связано с тем, что ваше приложение не имеет права создавать источник событий.

UPDATE

Как я могу настроить его так, чтобы 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", он наследует настройки и регистрируется как на LogFileAppender, так и на EventLogAppender.

Кстати, наименование регистратора EventLogAppender, возможно, немного запутанно: EventLogLogger может быть лучшим именем.

Ответ 2

Вы можете использовать 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");