繁体   English   中英

Log4net未记录

[英]Log4net is not logging

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

谢谢。

看起来您似乎缺少了<level> <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"/>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM