与 RELEASE 模式相比,log4net 在 DEBUG 模式下使用不同的 xml 配置文件

log4net use a different xml config file when in DEBUG mode compared to RELEASE mode

我有一个 webapp,我想在 DEBUG 模式下 运行 与 RELEASE 模式下 运行 使用不同的 log4net 配置文件。

我使用的是 log4net 版本 2.0.3。

在我的 AssemblyInfo.cs class 我有这个代码:

#if DEBUG
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4netDebug.xml",     Watch = true)]
#else
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4netLive.xml", Watch = true)]
#endif

在我的 Global.asax.cs class 我有这个代码:

log4net.Config.XmlConfigurator.Configure(); 
log = LogManager.GetLogger(typeof(GlobalApp));

(日志是 GlobalApp 的 public 静态成员。) 在我的 log4netDebug.xml 文件中我有这个代码:

<?xml version="1.0" encoding="utf-8"?>
<!-- Configuration for logging using log4net-->
<configuration>
<configSections>
<section name="log4net"  type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<!-- Show logging in the Visual Studio output window-->
<appender name="TraceAppender"
      type="log4net.Appender.TraceAppender" >
<layout type="log4net.Layout.PatternLayout">
   <conversionPattern value="%-6level - %message%newline" />
</layout>
</appender>
<appender
        name="AdoNetAppender"
        type="log4net.Appender.AdoNetAppender">
    <threshold>INFO</threshold>
    <bufferSize
    value="1" />
    <connectionType
    value="System.Data.SqlClient.SqlConnection, System.Data,  Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="data source=BLAH;initial  catalog=BLAH;integrated security=True;persist security info=True" />
<commandText value="INSERT INTO Logs ([Date],[Thread],[Source],[Level],  [Logger],[Message],[Exception],[HostName]) VALUES (@log_date, @thread, 'LOG SOURCE',@log_level, @logger, @message, @exception, @hostname)" />
    <parameter>
        <parameterName value="@log_date" />
        <dbType value="DateTime" />
        <layout type="log4net.Layout.RawTimeStampLayout" />
    </parameter>
    <parameter>
        <parameterName value="@thread" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%thread" />
        </layout>
    </parameter>
    <parameter>
        <parameterName value="@hostname" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%property{log4net:HostName}" />
        </layout>
    </parameter>
    <parameter>
        <parameterName value="@log_level" />
        <dbType value="String" />
        <size value="50" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%level" />
        </layout>
    </parameter>
    <parameter>
        <parameterName value="@logger" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%logger" />
        </layout>
    </parameter>
    <parameter>
        <parameterName value="@message" />
        <dbType value="String" />
        <size value="-1" />
        <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%message" />
        </layout>
    </parameter>
    <parameter>
        <parameterName value="@exception" />
        <dbType value="String" />
        <size value="-1" />
        <layout type="log4net.Layout.ExceptionLayout" />
    </parameter>
</appender>
<root>
    <level value="ALL" />
    <!-- Show logging in the Visual Studio output window-->
    <appender-ref ref="TraceAppender" />
    <appender-ref ref="AdoNetAppender" />
</root>
</log4net>
</configuration>

我已经测试了这个配置脚本,如果我把它放在我的 web.config 文件中,它就可以工作。 log4netDebug.xml 文件设置了始终复制 属性。

当我尝试做这样的事情时: System.IO.FileInfo fi = new System.IO.FileInfo("Log4NetDebug.xml"); log4net.Config.XmlConfigurator.ConfigureAndWatch(fi);

这也不行。
我已经阅读了几个描述如何执行此操作的 Whosebug 和其他网页,我似乎正在按照他们的建议去做,但它似乎仍然不起作用。

知道为什么吗?

如果您查看 Constructor for the FileInfo class,您会发现它需要 新文件的完全限定名称或相对文件名。.

所以当你这样做时System.IO.FileInfo fi = new System.IO.FileInfo("Log4NetDebug.xml");你需要指定文件的完整路径。

因为这是在网络应用程序中,您可能需要这样的东西:

var logFile = new FileInfo(Path.Combine(HttpRuntime.BinDirectory, "Log4NetDebug.xml"));