【发布时间】:2014-12-10 07:32:46
【问题描述】:
关于配置 log4net 有很多问题/答案,我已经研究了一段时间。是时候问我自己的问题了。 我的问题是我的“Web api”网络服务没有创建日志文件。一世 要在以下位置创建日志文件:C:\Logs。我已仔细检查我是否有权写入此文件夹。此外,我们使用 log4net 用于我们的功能测试,当我运行测试时,会创建文件 FunctionalTests.log。因此,我认为我们可以 排除权限。
我在这里做错了什么?
我的 AssemblyInfo.cs 文件中有这一行:
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]
我在应用程序启动时调用 XmlConfigurator.Configure()。在我的调试器中,我可以看到 Application_Start 被命中 以及调用的 Configure() 方法:
public class WebApiApplication : HttpApplication
{
protected void Application_Start()
{
XmlConfigurator.Configure();
HibernateConfig.InitHibernate();
}
这是我的 Log4Net.config 文件,位于我的项目的根级别:
<log4net debug="true">
<!-- Level 1 -->
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="C:\Logs\WebAPI.log"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="2" />
<maximumFileSize value="1000MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d %property{X-CLIENT-REQUEST-ID} %property{X-REQUEST-ID} [%t] %-5p %c %m%n"/>
</layout>
</appender>
<appender name="RequestLogAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="C:\Logs\WebAPIRequests.log"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="2" />
<maximumFileSize value="1000MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d %property{X-CLIENT-REQUEST-ID} %property{X-REQUEST-ID} [%t] %-5p %c %m%n"/>
</layout>
</appender>
<root>
<level value="ALL" />
<appender-ref ref="LogFileAppender" />
</root>
<logger additivity="false" name="Request">
<level value="INFO" />
<appender-ref ref="RequestLogAppender" />
</logger>
</log4net>
【问题讨论】:
-
旁白:如果您已经显式调用了
Configure,则不需要组装属性,事实上,因为它对于何时(如果)log4net 可以处理它非常不可靠,我建议不要依赖完全在它上面。只需从您的Application_Start拨打XmlConfigurator.ConfigureAndWatch()。 -
感谢您的评论。我已经删除了这个。
-
@JeroenMostert 你的评论应该是答案,你让我很开心!我无法弄清楚为什么 log4net 在 IIS 中不起作用,这都是程序集属性的错误,绝对使用来自
Application_Start的XmlConfigurator.ConfigureAndWatch()应该是要走的路