Подтвердить что ты не робот

Запись журналов в файл

У меня есть некоторые проблемы при записи журналов из log4net в файл. Кажется, я все делаю так, как описано в руководстве, но это не работает. Вот мой файл logging.config:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net>
    <appender name="FileAppender" type="log4net.Appender.FileAppender">
      <file value="log.txt" />
      <appendToFile value="true" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %message%newline" />
      </layout>
    </appender>
  </log4net>
</configuration>

Пожалуйста, помогите с примером файла конфигурации, который действительно работает.

4b9b3361

Ответ 1

У вас нет элемента <root>, который ссылается на ваш appender:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>

    <log4net>
      <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
        <file value="log.txt" />
        <appendToFile value="true" />
        <rollingStyle value="Size" />
        <maxSizeRollBackups value="10" />
        <maximumFileSize value="250KB" />
        <staticLogFileName value="true" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
        </layout>
      </appender>
      <root>
        <level value="INFO" />
        <appender-ref ref="RollingFileAppender" />
      </root>
    </log4net>
</configuration>

Ответ 2

Ниже приведено полное пошаговое руководство по добавлению Log4Net к вашему проекту в Visual Studio 2012 и .NET 4.5.

  • Добавить новое консольное приложение С# в ваше решение.

  • Выберите Tools >> Library Package Manager >> Manage NuGet Packages For Solution и выполните поиск log4net. Установите его и выберите, какие проекты вы хотите добавить ссылки log4net. enter image description here

  • Изменить Program.cs:

using System;
namespace Log4Net
{    
    class Program
    {
        private static readonly log4net.ILog log = log4net.LogManager.GetLogger
                (System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
        static void Main(string[] args)
        {
            Console.WriteLine("Writing to \"log.txt\" in the same directory as the .exe file.\n");
            log.Info("Info logging");
            try
            {
                throw new Exception("Exception!");
            }
            catch (Exception e)
            {
                log.Error("This is my error", e);
            }
            Console.WriteLine("[any key to exit]");
            Console.ReadKey();
            }
        }
    }
}
  1. Добавьте log4.config, щелкните правой кнопкой мыши и выберите Properties, затем выберите Copy to Output Directory - Copy If Newer.
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>

  <log4net>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="log.txt" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="250KB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <root>
      <level value="ALL" />
      <appender-ref ref="RollingFileAppender" />
    </root>
  </log4net>
</configuration>
  1. Изменить App.Config, чтобы он соответствовал следующему:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
    <appSettings>
        <add key="log4net.Config" value="log4.config"/>
        <add key="log4net.Config.Watch" value="True"/>
        <add key="log4net.Internal.Debug" value="False"/>
    </appSettings>
</configuration>
  1. Запустите программу и просмотрите файл log.txt, который создается в каталоге \bin\Debug\:

    2013-08-10 11:54:26,798 [10] INFO  Log4Net.Program [(null)] - Info logging
    2013-08-10 11:54:26,824 [10] ERROR Log4Net.Program [(null)] - This is my error
    System.Exception: Exception!
       at Log4Net.Program.Main(String[] args) in C:\Test\Log4Net\Program.cs:line 14
    
  2. В будущем, если вы хотите добавить log4net в другой проект, выберите Tools >> Library Package Manager >> Manage NuGet Packages For Solution выберите log4net и нажмите Manage, затем отметьте Проекты, которые вы хотите добавить log4net в. enter image description here

Ответ 3

Вы вызывали метод configure, когда приложение запускается в первый раз?

log4net.Config.XmlConfigurator.Configure();

Если да. Вы должны быть хорошими. Проверьте права доступа к файлу на записываемом диске.

Если вы хотите, вы можете включить внутреннюю отладку log4net, чтобы выяснить, что не так.

http://logging.apache.org/log4net/release/faq.html#troubleshooting

Ответ 4

Есть две вещи, которые вы можете сделать:

Один, если вы хотите использовать отдельный конфигурационный файл, добавив в файл app.config следующее: он будет автоматически настраивать журнал.

<?xml version="1.0"?>
<configuration>
    <appSettings>
        <add key="log4net.Config" value="log4.config"/>
        <add key="log4net.Config.Watch" value="True"/>
        <add key="log4net.Internal.Debug" value="False"/>
    </appSettings>
</configuration>

В противном случае вам необходимо инициировать ведение журнала в начале вашего приложения.

//Initiate logging based on web.config file
log4net.Config.XmlConfigurator.Configure();

// Create a logger for use in this class
log4net.ILog log4 = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

Ответ 5

Фантастические. Ответы правильные... кроме того, что они не работали для меня

Искал сеть и, наконец, обнаружил, что в Assembly.cs не хватает следующей строки:

[assembly: log4net.Config.XmlConfigurator]