【问题标题】:Yet another: log4net log file isn't created还有一个:未创建 log4net 日志文件
【发布时间】: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_StartXmlConfigurator.ConfigureAndWatch() 应该是要走的路

标签: asp.net-web-api log4net


【解决方案1】:

问题是 Visual Studio 没有将我的 log4net.config 文件复制到 bin 目录。修复:右键单击 log4net.config -> 属性 -> 始终复制。

我还有第二个问题要解决。我的配置文件没有被读取,即使在 bin 目录下也是如此。我编辑了我的 Web.config 文件并添加了这两行:

<appSettings>
    <add key="log4net.Config" value="Log4Net.config"/>
    <add key="log4net.Config.Watch" value="True"/>
</appSettings>

【讨论】:

    【解决方案2】:

    迟到总比没有好=]

    按照我在 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>
    

    在我的例子中,我创建了一个静态“日志助手”来集中所有日志调用

    我使用静态构造器来配置 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);
        }
    }
    

    希望有效果

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2011-11-10
      • 2011-02-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多