Log4net日志记录无法正常工作 - asp.net mvc

时间:2014-01-14 07:04:22

标签: asp.net-mvc log4net log4net-configuration

我的log4net配置就是这个,

    <?xml version="1.0" encoding="utf-8" ?>
     <log4netConfiguration>
     <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <appSettings>
    <add key="log4net.Config" value="log4net.config" />
  </appSettings>
  <log4net>   
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file type="log4net.Util.PatternString" value="C:\my_logs/my_web_logs/my_log_%date{ddMMyyyy}.log" />
      <appendToFile value="true" />      
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="5" />
      <maximumFileSize value="30MB" />
      <datePattern value="yyyyMMdd" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%4t %d{ABSOLUTE} %-5p %m%n"/>
        <!--<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] – %message%newline" />-->
      </layout>
    </appender>   
    <root>
      <level value="INFO" />
      <appender-ref ref="RollingFileAppender" />
    </root>
  </log4net>
</log4netConfiguration>

我有一个Logger助手类,

public static class Logger
    {
        private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

        public static log4net.ILog Log
        {            
            get { return log; }
        }
    }

在我的汇编信息中,我有这个条目,

// Configure log4net using the .config file 
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]

log4net.config是添加到Web项目的配置文件。

在代码中我使用logger类记录

Logger.Log.Info("User visits Sign In Page.");

设置上述设置时,记录功能一直有效。但突然伐木已停止工作。 但是当我使用上述设置创建一个新的asp.net mvc网站时,日志记录就可以了。 我试过IIS Express和本地IIS。在这两种情况下,记录都适用于我创建的测试应用程序。

我无法弄清楚为什么它没有记录?我怎么诊断这个?有什么可能的问题?

4 个答案:

答案 0 :(得分:13)

由我自己解决,原因是“由于某种原因”log4net配置未从程序集信息加载。我仍然不知道为什么会这样。

我尝试了不同帖子提出的很多修正。最后解决了这个问题。 this post中提到的解决方案帮助我解决了这个问题。

我添加了以下配置

    <!--These settings load the log4net configuration.-->
        <add key="log4net.Config" value="log4net.config"/>
        <add key="log4net.Config.Watch" value="True"/>

开始记录!

然后我从汇编信息

中删除了以下行
// Configure log4net using the .config file 
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]

答案 1 :(得分:2)

原因是Log4Net尝试从首次使用LogManager.GetLogger()的程序集加载配置。如果它是您的一个类库,它将忽略所有其他程序集中的属性。

最简单的解决方法是在您的初始文件中调用LogManager(例如Program.csGlobal.asax):

var logger = LogManager.GetLogger(typeof(Program));
logger.Info("Application started.");

//rest of app init.

这样做可以使用程序集属性获得预期的行为。

答案 2 :(得分:1)

我发现log4net不会加载webconfig配置,除非你调用log4net.Config.XmlConfigurator.Configure();在启动时。

    protected void Application_Start()
    {
        // your other codes

        log4net.Config.XmlConfigurator.Configure(); // must have this line
        Logger = log4net.LogManager.GetLogger(typeof(MvcApplication));

    }

答案 3 :(得分:0)

我有一个类似的问题:从IIS或IISExpress运行程序集时,不会得到任何日志记录输出。

但是,以上所有答案对我都没有作用。

在我的情况下,解决方案是将配置文件的路径指定为绝对路径。事实证明,IISExpress不会将当前目录设置为bin文件夹,log4net找不到配置文件,因此我不得不使用以下解决方法:

        string codeBase = Assembly.GetExecutingAssembly().CodeBase;
        // remove file:// part from uri
        UriBuilder ub = new UriBuilder(codeBase);
        string path = Uri.UnescapeDataString(ub.Path);

        var fi = new FileInfo(Path.Combine(Path.GetDirectoryName(path), "Logging.config.xml"));

        if (fi.Exists)
        {
            log4net.Config.XmlConfigurator.ConfigureAndWatch(fi);

            var logger = log4net.LogManager.GetLogger(typeof(WebApiApplication));
            logger.Info("Application started.");
        }
        else
        {
            throw new FileNotFoundException("log4net config file not found", fi.FullName);
        }