Log4net未进行日志记录

本文关键字:日志 记录 Log4net | 更新日期: 2023-09-27 18:25:19

我有一个小型控制台应用程序,它引用了一个库项目。我正在尝试使用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>

在我的main()中:

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);
}

谢谢。

Log4net未进行日志记录

<root>声明中似乎缺少<level>元素来告诉log4net实际记录的日志级别。

将您当前的根目录更改为这样可以解决您的问题吗?

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

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

<add key="log4net.Internal.Debug" value="true"/>