2015-10-22 59 views
0

我在记录错误时无法让log4net创建日志文件。Log4Net配置 - 无系统创建的日志文件

我使用ninject注入我与log4net的对象依赖关系,为香港专业教育学院创建了一个包装: -

public interface ILogManager 
{ 
    ILog GetLog(Type typeAssociatedWithRequestLog); 
} 

public class LogManagerAdapter : ILogManager 
{ 
    public ILog GetLog(Type typeAssociatedWithRequestLog) 
    { 
     var log = LogManager.GetLogger(typeAssociatedWithRequestLog); 

     return log; 
    } 
} 

在NinjectConfigurator.cs: -

private void ConfigureLog4net(IKernel container) 
{ 
    XmlConfigurator.Configure(); 

    var logManager = new LogManagerAdapter(); 

    container.Bind<ILogManager>().ToConstant(logManager); 
} 

private void AddBindings(IKernel container) 
{ 
    ConfigureLog4net(container); 
} 

在我的webconfig我有以下几种: -

<configSections> 
    <section name ="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/> 
    </configSections> 
    <log4net> 
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender"> 
     <file type="log4net.Util.PatternString" value="..\\..\\logs\\WebApi2Book.Api.Log"/> 
     <appendToFile value="true"/> 
     <maxSizeRollBackups value="-1"/> 
     <countDirection value="1"/> 
     <maximumFileSize value="5MB"/> 
     <rollingStyle value="Composite"/> 
     <preserveLogFileNameExtension value="true"/> 
     <staticLogFileName value="false"/> 
     <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/> 
     <layout type="log4net.Layout.PatternLayout"> 
     <conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception"/> 
     </layout> 
     <logger name="NHibernate"> 
     <level value="ERROR"/> 
     </logger> 
     <logger name="NHibernate.SQL"> 
     <level value="ERROR"/> 
     </logger> 
     <root> 
     <level value="ALL"/> 
     <appender-ref ref="LogFileAppender"/> 
     </root> 
    </appender> 
    </log4net> 

在Global.asax类中,Im测试记录器是实际的y被正确注入,然后在Application_Start()方法中测试记录错误。

protected void Application_Start() 
     { 
      var log = WebContainerManager.Get<ILogManager>().GetLog(typeof(WebApiApplication)); 

      log.Error("Yey!!!! works!"); 
      log.Debug("Yey!!!! works!! Debug"); 


     } 

我找不到任何问题,当我调试程序,我已经检查了IsDebugEnabled设置为TRUE,而在记录正确注入预期。

唯一的问题是没有生成日志文件。

+1

试日志文件的绝对路径,并确保运行您的Web应用程序的用户具有权限... –

回答

1

你的问题是,在你的根记录你引用所谓的“LogFileAppender”,但实际上你的appender被称为“RollingFileAppender进行”一个appender - 该附加目的地的名称必须是相同的两个地方:

<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender"> 
    … 
<root> 
    <level value="ALL"/> 
    <appender-ref ref="RollingFileAppender "/> 
</root>