Я не могу заставить работать log4net в моем веб-приложении :( - PullRequest
5 голосов
/ 15 апреля 2010

Я пытаюсь настроить log4net, но не могу заставить его работать. Я поместил это в мой Web.config:

<configSections>
  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>

<log4net>
  <appender name="TraceAppender" type="log4net.Appender.TraceAppender">
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
    </layout>
  </appender>

  <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
    <file value="logfile.log" />
    <appendToFile value="true" />
    <rollingStyle value="Composite" />
    <maxSizeRollBackups value="14" />
    <maximumFileSize value="15000KB" />
    <datePattern value="yyyyMMdd" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
    </layout>
  </appender>

  <root>
    <level value="DEBUG" />
    <appender-ref ref="RollingFileAppender" />
    <appender-ref ref="TraceAppender" />
  </root>
</log4net>

Затем в моем коде я выполняю:

log4net.Config.XmlConfigurator.Configure(new FileInfo(HttpContext.Current.Server.MapPath("~/Web.config")));
ILog log = LogManager.GetLogger("MainLogger");

if (log.IsDebugEnabled)
    log.Debug("lalala");

Но ничего не происходит. Я проверил переменную «log», и она содержит объект LogImpl, у которого включены все уровни ведения журнала. Я не получаю сообщение об ошибке или предупреждение о конфигурации, я не вижу ни одного файла в корне, в корзине или где-либо еще.

Что мне нужно сделать, чтобы это заработало?

Ответы [ 4 ]

9 голосов
/ 15 апреля 2010

Попробуйте написать:

log4net.Config.XmlConfigurator.Configure();

вместо этого, поскольку Web.config является местоположением по умолчанию, где будет выглядеть Log4Net.

В противном случае удалите всю эту строку из своего кода и вставьте в файл AssemblyInfo.cs следующее:

[assembly: log4net.Config.XmlConfigurator()]

Это настроит Log4Net на уровне сборки. Затем в своем коде просто создайте регистратор, подобный этому:

private static readonly ILog Log = LogManager.GetLogger(typeof(YourFunkyClass));
4 голосов
/ 15 апреля 2010

Есть ли у вас эта строка в вашем файле AssemblyInfo.cs?

[assembly: log4net.Config.XmlConfigurator()]

Кроме того, вы должны рассмотреть подход «typeof (YourClass)», используемый Эриком в своем ответе ниже. В первый раз я проголосовал за альтернативный ответ на один из моих. :)

У вас не определен TraceAppender.

У вас не настроен регистратор с именем «MainLogger»

<logger name="MainLogger">
  <level value="DEBUG"/>
  <appender-ref ref="RollingFileAppender" />
  <appender-ref ref="TraceAppender" />
</logger>

Также посмотрите здесь

0 голосов
/ 15 мая 2013

Вот мое рабочее решение:

Configuration oConfiguration = WebConfigurationManager.OpenWebConfiguration(oRequest.ApplicationPath);

log4net.Config.XmlConfigurator.Configure(new FileInfo(oConfiguration.FilePath));
0 голосов
/ 15 апреля 2010

Вам потребуется другой метод для настройки log4net: log4net.Config.XmlConfigurator.Configure().

Затем он автоматически прочитает web.config.

См. http://logging.apache.org/log4net/release/manual/configuration.html, в разделе ".configфайлы ».

...