Второй Log4net logger не пишет в уникальный файл - PullRequest
0 голосов
/ 27 ноября 2018

У меня есть приложение, которое использует Anotar.Log4Net для ведения журнала.Я не могу удалить Anotar.Log4Net, поскольку другие члены команды используют его.Я хотел бы добавить свой собственный файл журнала.Я добавил дополнительный appender файла в мой app.config с именем BGDEV.Я просмотрел пост здесь , чтобы увидеть, как другие решают задачу с двумя файловыми апдендерами.Желаемое поведение ниже для каждого регистратора, чтобы войти в свой собственный файл.Все входит в MainLog.txt.Это потому, что что-то не так с настройками app.config или у меня установлена ​​библиотека anotar?

<log4net>
<appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
  <file value="MainLog.txt"/>
  <appendToFile value="true"/>
  <rollingStyle value="Size"/>
  <maxSizeRollBackups value="5"/>
  <maximumFileSize value="10MB"/>
  <staticLogFileName value="true"/>
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date [%thread] %level %logger - %message%newline%exception"/>
  </layout>
</appender>
<appender name="BGDEV" type="log4net.Appender.RollingFileAppender">
  <file value="BG_Log.txt" />
  <appendToFile value="true" />
  <rollingStyle value="Composite" />
  <datePattern value="yyyyMMdd" />
  <maxSizeRollBackups value="10" />
  <maximumFileSize value="10MB" />
  <staticLogFileName value="true"/>
  <filter type="log4net.Filter.LevelRangeFilter">
    <levelMin value="INFO" />
    <levelMax value="FATAL" />
  </filter>
</appender>
<root>
  <level value="INFO"/>
  <appender-ref ref="FileAppender"/>
</root>
<logger additivity="false" name="BGDev">
  <level value="INFO"/>
  <appender-ref ref="BGDev" />
</logger>

В коде я создаю регистратор и использую его.Что-то не так с моим файлом конфигурации, или это потому, что я использую

private static readonly ILog otherLog = LogManager.GetLogger("BGDEV");
otherLog.Info("TEST OTHER LOG");

1 Ответ

0 голосов
/ 27 ноября 2018

У вас есть пара проблем с именами в вашем коде и конфиге.Имена чувствительны к регистру - вы определяете регистратор с именем BGDev, но вы звоните GetLogger("BGDEV"), так как никакого регистратора с именем BGDEV не существует, он возвращается к корневому регистратору.

Ваш регистратор с именем BGDev также ссылается на приложение с именем BGDev, однако, опять же, такого приложения не существует, так как вы определяете его с помощью имени в верхнем регистре BGDEV.

Наконец, ваш регистратор BGDev должен иметьраздел <layout>...</layout>, иначе он не сможет форматировать сообщения журнала.

Если вы исправите эти проблемы, он должен работать так, как вы ожидаете.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...