log4net在Windows Forms中无法写入日志文件。

4

我正在使用.NET Framework 4.0和log4net 1.2.13开发Windows窗体应用程序。

这是我第一次在Windows窗体应用程序中使用log4net,但它不起作用。也许我忘记了某个配置步骤,但现在它不起作用:我找不到日志文件

这是我实例化记录器的方式:

public partial class MainForm : Form
{
    private static readonly log4net.ILog _logger =
        log4net.LogManager.GetLogger(typeof(MainForm));

以下是 App.Config 的内容:

<log4net xsi:noNamespaceSchemaLocation="http://csharptest.net/downloads/schema/log4net.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <appender type="log4net.Appender.RollingFileAppender" name="AppLogErrorAppender">
    <file value="D:\\AppError.log" />
    <appendToFile value="true" />
    <rollingStyle value="Date" />
    <datePattern value=".yyyyMMdd.lo\g" />
    <maximumFileSize value="5MB" />
    <maxSizeRollBackups value="-1" />
    <countDirection value="1" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
    </layout>
  </appender>
  <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
    </layout>
  </appender>
  <logger name="AppLog">
    <level value="ERROR" />
    <appender-ref ref="AppLogErrorAppender" />
  </logger>
  <root>
      <level value="ERROR" />
      <appender-ref ref="AppLogErrorAppender" />
      <appender-ref ref="ConsoleAppender" />
  </root>
</log4net>

我正在这里记录日志:

public const string LogExceptionNameMessageFormatString = "EXCEPTION: {0} - Message: {1}";

private void LogError(string exceptionMessage, string exceptionName)
{
    _logger.ErrorFormat(LogExceptionNameMessageFormatString, exceptionName, exceptionMessage);
}

我在它上面设置了断点,但它停止了。

我做错了什么?


4
“doesn't work”非常模糊 - 你观察到了什么行为?你能否发布一个简短但完整的程序来演示这个问题,而不仅仅是一小段代码片段? - Jon Skeet
我已经更新了我的问题。问题是我找不到日志文件。 - VansFannel
当应用程序尝试记录某些内容(当您调用 _logger.Info 等时)时,将生成日志文件,而不是应用程序启动时。您是否正在记录任何内容?您是否已使用您的配置初始化了 log4net?请发布相关代码。 - Panagiotis Kanavos
那不像是一个 App.Config 文件,更像是一个单独的 log4net 配置文件。您需要初始化 log4net 以读取配置文件:https://logging.apache.org/log4net/release/manual/configuration.html。 - Stuart Grassie
@StuartGrassie 这是我的 App.Config 文件的一部分。我没有放所有内容,以免放入不相关的数据。 - VansFannel
3个回答

7

Program.cs:

[STAThread]
private static void Main(string[] args)
{
    log4net.Config.XmlConfigurator.Configure();

    /* other stuff */
}

在配置完成后,我通常也会立即在void Main中记录一些内容。

App.config:

您需要记得将log4net配置节放在<configSections>的第一个元素位置:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
        <configSections>
                <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
        </configSections>
        <startup>
                <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/>
        </startup>

        <log4net>
                <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
                        <file value="log.log"/>
                        <appendToFile value="true"/>
                        <rollingStyle value="Size"/>
                        <maxSizeRollBackups value="1"/>
                        <maximumFileSize value="5MB"/>
                        <staticLogFileName value="true"/>
                        <layout type="log4net.Layout.PatternLayout">
                                <conversionPattern value="%newline%date [%thread] %-5level %logger - %message%newline%exception"/>
                        </layout>
                </appender>

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

                <root>
                        <level value="ALL"/>
                        <appender-ref ref="DebugAppender"/>
                        <appender-ref ref="RollingFileAppender"/>
                </root>
        </log4net>
</configuration>

感谢您的回答。log4net的“AppLogErrorAppender”配置有问题。 - VansFannel
关于你的话,我认为没有必要将log4net配置部分放在<configSections>的第一个元素位置。但是,你需要记住将其放入<configSections>中。 - Wang Jijun

1
你需要调用:

  XmlConfigurator.Configure();

在记录任何内容之前,需要初始化log4net并读取配置。

1

我花了一些时间在我的应用程序中设置log4net并使其工作。以下是我学到的内容:

在您的代码中引用log4net,通过调用GetLogger创建一个日志,并使用其中一个日志记录方法写入日志。

using log4net;
...
private static ILog Log;
...
Log = log4net.LogManager.GetLogger("Ref-A");
Log.Info("test-A");
Log = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().Name);
Log.Debug("test-B");

2018-05-29 21:32:58,574 [1] Ref-A - testA
2018-05-29 21:32:58,575 [1] MyMethod - testB

当调用GetLogger时,您需要传递一个字符串作为日志行的前缀,通常是当前类和/或方法。
在AssemblyInfo.cs中,您需要添加以下其中一行。您可以使用using子句引用log4net.Config或在对XmlConfigurator的调用前加上前缀。
第一种语法不指定文件名,将使用App.config。我在文档和一些文章中发现的第二种语法是用于使用单独的log4net.config文件。最后,如果在依赖程序集中使用log4net,则需要指定将生成的配置文件的名称,以便log4net在那里查找而不是在调用应用程序的App.config中查找。
//use App.config
using log4net.Config;
[assembly: XmlConfigurator(Watch = true)]

//use log4net.config
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config",Watch = true)]

//use myLibrary.dll.config
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "myLibrary.dll.config",Watch = true)]

这是我使用的App.config。它适用于上述情况1和3以及绝对文件路径。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net>
    <root>
      <level value="ALL" />
      <appender-ref ref="console" />
      <appender-ref ref="file" />
    </root>
    <appender name="console" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date %level %logger - %message%newline" />
      </layout>
    </appender>
    <appender name="file" type="log4net.Appender.RollingFileAppender">
      <file value="c:\temp\myLog.log" />
      <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" />
      </layout>
    </appender>
  </log4net>
</configuration>

另外还有几个提示。

  • 调试时,检查GetLogger返回的值的属性 - 如IsDebugEnabled、IsInfoEnabled等 - 如果它们都设置为false,则表示你的日志配置有误,日志不会写入任何内容。

  • 如果有多个项目使用log4net,其中一个项目创建日志失败,则其他项目也将失败。至少在我的情况下是这样,因为许多dll文件调用了同一个基类,而基类未能创建第一个日志。程序中的所有日志都无法工作。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接