Log4NET AdoNetAppender连接字符串引用

dav*_*ooh 4 .net c# log4net web-config

我想使用Log4NET登录我的数据库并按照一些教程我看到我必须为DAO appender配置连接字符串.

我已经在我的web.config中有一个用于数据库连接的连接字符串,所以我想知道我是否可以引用它而不是设置一个新的.

我通常会更改连接字符串以从dev DB切换到生产DB,因此共享相同的连接参数可能非常有用.

stu*_*rtd 6

编辑:自发布以来,log4net现在支持在配置中指定连接字符串名称.来自https://issues.apache.org/jira/browse/LOG4NET-88 -

这会将新的"connectionStringName"属性(和相应的ConnectionStringName)属性添加到AdoNetAppender类.这是<ConnectionStrings>对App.config或Web.config文件部分中的连接字符串的引用.

这个答案有一个例子.

如果您没有在该<ConnectionStrings>部分中定义的连接字符串,则可以使用此类在运行时设置连接字符串:

SetConnectionString在配置log4net之后立即使用连接字符串调用.

但是,我会注意到以下几点:

Log4net数据库追加器不喜欢在没有连接字符串的情况下创建,并抛出(内部)错误 - 并且在单元测试期间,我看到在给出假连接字符串时测试需要超过10秒.

public static class LogConfigurator
{
   public static void SetConnectionString(string connectionString)
   {
        Hierarchy logHierarchy = log4net.LogManager.GetRepository() as Hierarchy;

        if (logHierarchy == null)
        {
            throw new InvalidOperationException
               ("Can't set connection string as hierarchy is null.");
        }

        var appender = logHierarchy.GetAppenders()
                                   .OfType<AdoNetAppender>()
                                   .SingleOrDefault();

        if (appender == null)
        {
            throw new InvalidOperationException
              ("Can't locate a database appender");
        }

        appender.ConnectionString = connectionString;
        appender.ActivateOptions();
   }
}
Run Code Online (Sandbox Code Playgroud)