关于配置log4net有很多问题/答案,我一直在看它们。是时候问我自己的问题了。 我的问题是我的网络api" Web服务不会创建日志文件。一世 想要在以下位置创建日志文件: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>
答案 0 :(得分:5)
问题是visual studio没有将我的log4net.config文件复制到bin目录。解决方法:右键单击log4net.config - &gt;属性 - &gt;总是复制。
我还有第二个问题要解决。我的配置文件未被读取,即使在bin目录下也是如此。我编辑了我的Web.config文件并添加了这两行:
<appSettings>
<add key="log4net.Config" value="Log4Net.config"/>
<add key="log4net.Config.Watch" value="True"/>
</appSettings>
答案 1 :(得分:0)
迟到总比没有=]
在web.config上按照我的配置
<log4net debug="false">
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender,log4net">
<param name="File" value="log/log" />
<param name="AppendToFile" value="true" />
<param name="rollingStyle" value="Composite" />
<param name="datePattern" value="yyyyMMdd" />
<param name="MaximumFileSize" value="100MB" />
<param name="MaxSizeRollBackups" value="-1" />
<param name="StaticLogFileName" value="false" />
<layout type="log4net.Layout.PatternLayout,log4net">
<param name="ConversionPattern" value="%d [%t] %-5p - %m%n" />
</layout>
</appender>
<root>
<priority value="ALL" />
<appender-ref ref="LogFileAppender" />
</root>
</log4net>
在我的情况下,我创建了一个静态&#34; Log Helper&#34;集中所有日志调用
我使用静态构造函数来配置log4net行为,如下所示:
public class LogHelper
{
private static readonly ILog Log;
static LogHelper()
{
Log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
log4net.Config.XmlConfigurator.Configure();
}
public static void RegistrarLogInfo(string message)
{
Log.Info(message);
}
public static void RegistrarLogError(string message)
{
Log.Error(message);
}
}
希望它有效