有许多关于配置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>
Application_Start
使用XmlConfigurator.ConfigureAndWatch()
应该是正确的方法。 - Alberto Rechy