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);
}
谢谢。
在<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"/>