【问题标题】:GlobalContext.Properties doesn't work although XMLConfigurator.Configure is called afterwards尽管之后调用了 XMLConfigurator.Configure,但 GlobalContext.Properties 不起作用
【发布时间】:2021-04-22 15:06:35
【问题描述】:

我在 log4net appender 中设置了一个全局属性,我想在其中获取 exe 的当前路径作为日志文件的路径。

这是我的 App.config:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net>
    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="%property{LogFileName}.log"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="2" />
      <maximumFileSize value="10MB" />
      <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>
</configuration>

所以在这里我将我的属性设置为%property{LogFileName}.log

这是 sn-p,我在脚本中设置了这个属性:

        var directory = Path.GetDirectoryName(Process.GetCurrentProcess().MainModule.FileName);

        GlobalContext.Properties["LogFileName"] = directory + "/AccesDBReader"; //log file path
        log4net.Config.XmlConfigurator.Configure();

我在设置属性后设置了XMLConfigurator.Configure(),所以不明白怎么回事。

【问题讨论】:

    标签: c# logging configuration log4net


    【解决方案1】:

    指定file 设置值的方式应如下所示。

    注意file 标签被使用而不是param
    并包含 type="log4net.Util.PatternString" 说明符。

    <file type="log4net.Util.PatternString" value="%property{LogFileName}.log" />
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-09-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-07-01
      • 2015-12-24
      相关资源
      最近更新 更多