[英]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.