Конфигурация с несколькими приложениями log4net - PullRequest
0 голосов
/ 20 июля 2011

Извините за задание log4net для новичков, это похоже на обычную настройку, но я не могу найти пример.

Я пытаюсь получить следующую настройку с помощью моей конфигурации log4net:

Два дополнения:

  • File_Appender -> log4net.Appender.RollingFileAppender
  • Smtp_Appender -> log4net.Appender.SmtpAppender
    (для порога оценки установлено значение ОШИБКА)

Много регистраторов:

  • Все регистраторы (root) -> INFO, WARN, ERROR -> File_Appender
  • Все регистраторы (root) -> ОШИБКА -> Smtp_Appender
  • Определенные регистраторы -> DEBUG -> File_Appender
  • Определенные регистраторы -> INFO -> Smtp_Appender

Я не уверен, как настроить «корневой» регистратор для записи разных уровней в разные приложения (я не хочу явно настраивать каждый регистратор для регистрации ошибок в Smtp_Appender).

1 Ответ

0 голосов
/ 20 июля 2011

Я закончил тем, что создал свой собственный фильтр appender, который позволяет установить более низкий уровень соответствия для явно указанных регистраторов:

public class MultipleLevelFilter : LevelMatchFilter
{
    public MultipleLevelFilter()
    {
        LevelToMatchForSpecificLoggers = Level.Fatal;
        _specificLoggers = new string[0];
    }

    /// <summary>
    /// Gets or sets the level to match for loggers
    /// specified in the <see cref="SpecificLoggers"/> property.
    /// </summary>
    /// <value>The level to match for specific loggers.</value>
    public Level LevelToMatchForSpecificLoggers { get; set; }

    private string[] _specificLoggers;
    /// <summary>
    /// Gets or sets a comma separated list of "specific" loggers.
    /// For these loggers, <see cref="LevelToMatchForSpecificLoggers"/>
    /// property is checked to see whether they should be logged.
    /// </summary>
    /// <value>The specific loggers.</value>
    public string SpecificLoggers 
    {
        get { return string.Join(",", _specificLoggers); }
        set
        { 
            _specificLoggers = value.Split(',').Select(s=>s.Trim()).ToArray();
        }
    }

    /// <summary>
    /// Tests if filter matches the specified logging event.
    /// </summary>
    /// <param name="loggingEvent">the event to filter</param>
    public override FilterDecision Decide(LoggingEvent loggingEvent)
    {
        // if base.LevelToMatch is matched, always match
        if (loggingEvent.Level >= LevelToMatch)
           return AcceptOnMatch ? FilterDecision.Accept : FilterDecision.Deny; 

        // if specific level is matched, check if logger name matches
        if (loggingEvent.Level >= LevelToMatchForSpecificLoggers)
        {
            string name = loggingEvent.LoggerName;
            for (int i = 0; i < _specificLoggers.Length; i++)
                if (name == _specificLoggers[i])
                    return AcceptOnMatch ?
                        FilterDecision.Accept : FilterDecision.Deny;
        }

        // continue with next filter
        return FilterDecision.Neutral;
    }
}

Использование:

<appender name="Smtp_Appender" 
     type="Ster.Log4Net.DelayedSendSmtpAppender">

  <!-- ... common properties (from, to, etc) -->

  <!-- our custom filter -->      
  <filter type="MyNamespace.MultipleLevelFilter">

    <!-- this level is ALWAYS matched -->
    <levelToMatch value="ERROR" />

    <!-- this level is matched only for specific loggers -->
    <levelToMatchForSpecificLoggers value="INFO" />

    <!-- these are the "specific" loggers (comma separated) -->
    <specificLoggers value="SomeLogger, SomeOtherLogger" />

  </filter>
  <!-- always end the filter chain with DenyAll -->
  <filter type="log4net.Filter.DenyAllFilter" />

</appender>

<root>
  <priority value="INFO" />
  <appender-ref ref="File_Appender" />
  <appender-ref ref="Smtp_Appender" />
</root>
...