【发布时间】:2011-02-08 07:50:24
【问题描述】:
我正在尝试设置 log4net,但我无法使其工作。我已经把它放在了我的 Web.config 中:
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="TraceAppender" type="log4net.Appender.TraceAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="logfile.log" />
<appendToFile value="true" />
<rollingStyle value="Composite" />
<maxSizeRollBackups value="14" />
<maximumFileSize value="15000KB" />
<datePattern value="yyyyMMdd" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<root>
<level value="DEBUG" />
<appender-ref ref="RollingFileAppender" />
<appender-ref ref="TraceAppender" />
</root>
</log4net>
然后,在我的代码中执行:
log4net.Config.XmlConfigurator.Configure(new FileInfo(HttpContext.Current.Server.MapPath("~/Web.config")));
ILog log = LogManager.GetLogger("MainLogger");
if (log.IsDebugEnabled)
log.Debug("lalala");
但是什么也没发生。我检查了“log”变量,它包含一个启用了所有日志记录级别的 LogImpl 对象。我没有收到错误或配置警告,我在根目录、bin 或任何地方都看不到任何文件。
我必须做些什么才能让它发挥作用?
【问题讨论】:
-
如果您可以在 Visual Studio 中进行调试,请在应用启动时检查“输出”窗口。 log4net 在那里输出有关配置错误的任何信息。
-
您是否尝试过为
file属性设置绝对路径? (例如C:\logfile.log) -
除了下面的优秀答案之外,您应该在应用程序进程的整个生命周期内只调用一次配置,例如在 Global.asax 中的应用程序开始中。
标签: .net asp.net logging log4net