Запись логов в файл - PullRequest
36 голосов
/ 21 марта 2012

У меня проблемы с записью журналов из 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>

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

Ответы [ 5 ]

77 голосов
/ 10 августа 2013

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

  1. Добавление нового консольного приложения C # в ваше решение.

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

  3. Редактировать 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();
            }
        }
    }
}
Добавьте 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>
Редактировать 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>

Запустите программу и просмотрите файл 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

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

42 голосов
/ 21 марта 2012

У вас, похоже, нет элемента <root>, который ссылается на вашего аппендера:

<?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>
18 голосов
/ 21 марта 2012

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

log4net.Config.XmlConfigurator.Configure();

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

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

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

6 голосов
/ 21 марта 2012

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

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

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

//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);
3 голосов
/ 19 июля 2016

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

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

[assembly: log4net.Config.XmlConfigurator]
...