Log4Net在发布模式下未记录错误(.net控制台APP)

时间:2019-02-26 15:07:53

标签: log4net

您好,我在控制台APP中使用Log4Net

这是组装文件中的配置

[程序集:log4net.Config.XmlConfigurator(ConfigFile =“ log4net.config”,Watch = true)]

下面是log4net.config

 <?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <log4net>
    <appender name="InfoRollingLogFileAppender"

    type="log4net.Appender.RollingFileAppender,log4net">
      <param name="File" value="WarningLogger.txt" />
      <param name="AppendToFile" value="true" />
      <param name="MaxSizeRollBackups" value="10" />
      <param name="MaximumFileSize" value="10240KB" />
      <param name="RollingStyle" value="Size" />
      <param name="StaticLogFileName" value="true" />
      <param name="Threshold" value="DEBUG"/>
      <layout type="log4net.Layout.PatternLayout,log4net">
        <param name="ConversionPattern" value="%p [%d{dd MMM HH:mm:ss}][%l]- %m%n" />
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <levelMin value="WARN" />
        <levelMax value="WARN" />
      </filter>
    </appender>
    <root>
      <level value="debug" />
      <appender-ref ref="InfoRollingLogFileAppender" />
      <appender-ref ref="ErrorRollingLogFileAppender" />
    </root>
  </log4net>
</configuration>

对于初始化log4net,我正在使用以下配置。

  private static readonly log4net.ILog Log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

这东西在调试模式下可以完美地工作。相同的配置在发布模式下不起作用。

让我知道是否有解决方案

2 个答案:

答案 0 :(得分:0)

当静态方法初始化时,没有GetCurrentMethod()。DeclaringType。这可能就是为什么它在发行模式下不起作用的原因。

答案 1 :(得分:0)

通过在控制台的启动文件或程序文件中添加配置来解决该问题。

 XmlConfigurator.Configure(new FileInfo(ConfigurationManager.AppSettings["log4net-config-file"]));