【问题标题】:log4net on Windows Forms doesn't write log fileWindows 窗体上的 log4net 不写入日志文件
【发布时间】:2015-06-29 08:45:40
【问题描述】:

我正在使用 .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);
}

我有一个断点,它停止了。

我做错了什么?

【问题讨论】:

  • “不起作用”非常模糊 - 您观察到什么行为?您能否发布一个简短但完整的程序来演示该问题,而不仅仅是一个 sn-p?
  • 我已经更新了我的问题。问题是我找不到日志文件。
  • 日志文件是在应用程序尝试记录某些内容时生成的(当您调用 _logger.Info 等时),而不是在应用程序启动时生成。你在记录什么吗?您是否使用配置初始化了 log4net?请贴出相关代码
  • 这看起来不像 App.Config,它看起来像一个单独的 log4net 配置文件。你需要初始化 log4net 来读取配置文件:logging.apache.org/log4net/release/manual/configuration.html
  • @StuartGrassie 这是我的 App.Config 文件的一部分。我没有把所有不相关的数据都放好。

标签: c# winforms log4net


【解决方案1】:

程序.cs:

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

    /* other stuff */
}

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

App.config:

您需要记住将 log4net 配置部分作为&lt;configSections&gt; 的第一个元素:

<?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 配置有问题。
  • 关于你的话 [你需要记住将 log4net 配置部分作为 的第一个元素:] 我认为没有必要将 log4net 配置部分作为.. 的第一个元素
【解决方案2】:

您需要致电:

  XmlConfigurator.Configure();

在记录任何内容之前。这将初始化 log4net 并读取配置。

【讨论】:

    【解决方案3】:

    我花了一段时间在我的应用程序中设置 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 调用相同的基类并且基类无法创建第一个日志。程序中所有位置的所有日志也不起作用。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2023-03-31
      • 2016-05-08
      • 2012-11-11
      • 2012-11-03
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多