0

我有一个小型控制台应用程序,它引用了一个库项目。我正在尝试使用 log4net 记录可能的错误。当我从主项目中调用例如它时它可以工作Log.Debug(myErrorMsg),但是当我尝试从库项目中做同样的事情时,它什么也没写。你能告诉我是什么原因造成的吗?

在我的 app.config 中:

<configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
</configSections>
<log4net>
    <root>
       <appender-ref ref="LogFileAppender" />
    </root>
    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" >
      <param name="File" value="C:\MyProject\bin\Debug\log.txt" />
      <param name="AppendToFile" value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="10MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%-5p%d{yyyy-MM-dd hh:mm:ss} – %m%n" />
      </layout>
    </appender>
</log4net>

在我的主要()中:

XmlConfigurator.Configure(); 

在我的 dll 项目中:

internal static readonly ILog Log = LogManager.GetLogger(typeof(FileWatcherLogic));

...

catch (Exception ex)
{
    var msg = string.Format("Error handling file {0}: {1}", fullPath, ex.Message);
    Console.Write(msg);
    Log.Error(msg);
}

谢谢。

4

1 回答 1

1

看起来您在声明中缺少告诉 log4net 实际记录哪些日志级别的<level>元素。<root>

将您当前的根更改为此是否可以解决您的问题?

<root>
   <level value="ALL" /> <!-- or "DEBUG", "WARN", "INFO", etc -->
   <appender-ref ref="LogFileAppender" />
</root>

或者,如果这不起作用 - 您可以将此密钥添加到您的应用程序或 web.config 中,<appSettings>以获取 log4net 写入控制台的详细调试信息,以准确告诉您出了什么问题:

<add key="log4net.Internal.Debug" value="true"/>
于 2013-07-29T19:29:55.497 回答