当项目设置为发布版本时,log4net不起作用

时间:2017-01-05 15:50:37

标签: .net log4net

当我在调试模式下构建项目时,log4net正常工作,因此创建日志文件并按预期写入。但是,当我在发布模式下构建项目并将文件复制到生产服务器时,log4net不会创建日志文件或写入日志文件。

如果我使用调试模式复制文件,log4net在生产服务器中工作。

我启用了内部调试。在发布模式下运行时,内部日志文件显示:

  

log4net:Assembly [WebAPI,Version = 1.0.0.0,Culture = neutral,PublicKeyToken = null]没有指定RepositoryAttribute。

webconfig文件:

  <log4net debug="true">   
    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="webapi.log" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="2" />
      <maximumFileSize value="1MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%d [%t] %-5p %c %m%n" />      
      </layout>
    </appender>
    <root>
      <level value="ALL" />
      <appender-ref ref="LogFileAppender" />
    </root>
  </log4net>
  <system.diagnostics>
    <trace autoflush="true">  
      <listeners>
        <add
          name="textWriterTraceListener"
          type="System.Diagnostics.TextWriterTraceListener"
          initializeData="appTrace.txt" />
      </listeners>
    </trace>
  </system.diagnostics>

如何在发布模式下构建log4net?

1 个答案:

答案 0 :(得分:0)

尝试将[assembly:RepositoryAttribute(&#34; Your.Namespace.Here&#34;)]添加到WebAPI项目中的AssemblyInfo.cs。