web-dev-qa-db-ja.com

レベルに基づいてエラーをさまざまなアペンダーに送信するようにlog4netを構成する

Infoレベル以上をXMLアペンダーに送信し、Error/FatalレベルをEventLogアペンダーに送信します。

Configのルート要素を変更する必要があると収集しましたが、構文に苦労しています。特定のレベルまたはレベルの範囲の正しいアペンダーにログを送るための構成構文は何ですか?

これはこれまでの設定です:

<log4net>
  <appender name="SomeXmlAppender" type="log4net.Appender.RollingFileAppender">
    ...
  </appender>
  <appender name="SomeEventLogAppender" type="log4net.Appender.EventLogAppender">
    ...
  </appender>
  <root>
    <level value="DEBUG" />
    <appender-ref ref="SomeXmlAppender" />
    <appender-ref ref="SomeEventLogAppender" />
  </root>
</log4net>

編集:ありがとう@agileguy。その投稿には確かに私が必要とした構文が含まれていました。作業ソリューションは次のようになります。

<log4net>
  <appender name="SomeXmlAppender" type="log4net.Appender.RollingFileAppender">
    ...
    <evaluator type="log4net.Core.LevelEvaluator">
      <threshold value="INFO"/>
    </evaluator>
    <filter type="log4net.Filter.LevelRangeFilter">
      <levelMin value="INFO" />
      <acceptOnMatch value="true" />
    </filter>
    <filter type="log4net.Filter.DenyAllFilter" />
  </appender>
  <appender name="SomeEventLogAppender" type="log4net.Appender.EventLogAppender">
    ...
    <evaluator type="log4net.Core.LevelEvaluator">
      <threshold value="ERROR"/>
    </evaluator>
    <filter type="log4net.Filter.LevelRangeFilter">
      <levelMin value="ERROR" />
      <acceptOnMatch value="true" />
    </filter>
    <filter type="log4net.Filter.DenyAllFilter" />
  </appender>
  <root>
    <level value="DEBUG" />
    <appender-ref ref="SomeXmlAppender" />
    <appender-ref ref="SomeEventLogAppender" />
  </root>
</log4net>
43
grenade

これは、アペンダー内のthresholdまたはfilterエレメントを使用して行うことができます。

しきい値は、アペンダーの直下に含めることができ、包含フィルターとして機能するか、またはevaluatorの下に置くことができます。

<evaluator type="log4net.Core.LevelEvaluator">
  <threshold value="ERROR"/>
</evaluator>

該当する場合は、バッファリング(即時出力)をスキップするための包括的なフィルターとして機能します。



完全な説明( ソース ):

<threshold value="ERROR" />

しきい値はAppenderSkeletonに実装されているため、ほとんどすべてのアペンダーでサポートされています。これは、しきい値を下回るレベルのイベントのロギングを無視するために使用される単純なテストです。しきい値は早期にチェックされ、簡単なテストは非常に効果的です。

フィルターを使用してしきい値と同じ動作を指定する別の方法があります。フィルターは非常に柔軟性が高く、プラグイン可能であるため、独自のカスタムロジックを開発してフィルターチェーンに挿入することもできます。

<filter type="log4net.Filter.LevelRangeFilter">
    <levelMin value="ERROR" />
    <levelMax value="OFF" />
</filter>

しきい値チェックと同様に、フィルターはAppenderSkelton基本クラスで実装され、ほとんどすべてのアペンダーでサポートされています。上記のフィルターは<threshold value="ERROR" />と同じ効果があります。これは、ERRORからOFF(包括的)の範囲のレベルを持つすべてのイベントを許可するLevelRangeFilterです。 OFFは最高レベルの名前であり、逆にALLは最低レベルの名前であることに注意してください。

複数のフィルターをチェーン化して出力されるイベントをきめ細かく制御できるため、フィルターには大きな柔軟性があります。このため、パフォーマンスの点でもコストが高くなります。チェーン内の各フィルターはオブジェクトであり、正しい一連のアクションを決定するように求められます。しきい値フィルタリングの単純なケースでは、フィルターよりもThresholdプロパティを使用する必要があります。

EvaluatorBufferingAppenderSkeletonによって実装されるため、この基本クラスを拡張し、バッファリングをサポートするアペンダーによってのみサポートされます。 SmtpAppenderはそのようなアペンダーの1つです。

Evaluatorは、ロギングイベントをバッファリングするのではなく、すぐに書き込み/送信するかどうかを決定するためにBufferingAppenderSkeletonによって使用されるプラグ可能なオブジェクトです。エバリュエーターがイベントが重要であると判断した場合、現在のバッファーの内容全体がイベントと共に送信されます。エバリュエーターは、イベントを破棄しないという点で、しきい値やフィルターのように機能しません。

14
Danny Varod

アペンダーごとに異なるしきい値プロパティを設定できます。しきい値レベルより低いレベルのすべてのログイベントは、アペンダーによって無視されます。 2つのアペンダーの下に貼り付けています。1つはファイル用、もう1つはデータベース用です(接続文字列を設定する必要があります)。データベースアペンダーには、エラーのみがデータベースに保存されることを示すしきい値プロパティがあります。

<configuration>
  <log4net>
    <!--Database appender-->
    <appender name="DbAppender" type="log4net.Appender.ADONetAppender">
      <bufferSize value="0" />
      <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      <connectionString value="Data Source=AEG-PC\SQLEXPRESS;Initial Catalog=JCZ6;Uid=sa;Pwd=qwerty;" />
      <commandText value="INSERT INTO Log4Net ([date],[thread],[level],[logger],[message],[exception]) VALUES 
         (@log_date, @thread, @log_level, @logger, @message, @exception)" />
      <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="%t" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@log_level" />
        <dbType value="String" />
        <size value="10" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%p" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@logger" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%c" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@message" />
        <dbType value="String" />
        <size value="4000" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%m" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@exception" />
        <dbType value="String" />
        <size value="4000" />
        <layout type="log4net.Layout.ExceptionLayout" />
      </parameter>
      <threshold value="Error" /> <!--THIS IS THE IMPORTANT LINE-->
    </appender>
    <!--File appender-->
    <appender name="FileAppender" type="log4net.Appender.FileAppender">
      <file value="log-file.txt" />
      <appendToFile value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <root>
      <level value="INFO" />
      <appender-ref ref="FileAppender" />
      <appender-ref ref="DbAppender" />
    </root>
  </log4net>
</configuration>

同じ質問がありました。元の質問を理解しているとすると、特定の出力を1つのアペンダーに送信し、残りを他のアペンダーに送信するため、しきい値は機能しないようです。上記のように、LevelRangeFilterを使用して機能させることができました。 ERROR、INFO、WARNを1つのアペンダーに移動し、他のすべてを別のアペンダーに移動したいのですが、ERROR、INFO、WARNは使用しませんでした。

これは私のために働いた設定です:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
    </configSections>
    <log4net>
        <appender name="LoggingAppender" type="log4net.Appender.FileAppender" >
            <file value="logs.txt" />
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="INFO"/>
                <levelMax value="OFF"/>
            </filter>
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
            </layout>
        </appender>
        <appender name="TracingAppender" type="log4net.Appender.FileAppender" >
            <file value="traces.txt" />
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="ALL"/>
                <levelMax value="DEBUG"/>
            </filter>
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
            </layout>
        </appender>
        <root>
            <appender-ref ref="LoggingAppender"/>
            <appender-ref ref="TracingAppender"/>
        </root>
    </log4net>
</configuration>

ありがとう、ニック

2
nickdu