0

私は、過去 1 日間、log4net の問題を解決しようとしてきました。要件は、処理される特定のサーバー側イベントに基づいて一意のログ ファイルを作成する複数のロガーがあることです。問題は、複数のアペンダを作成すると、ログ ファイルへの出力が常に NULL になることです。

以下は、私の app.config ファイル内の関連する log4net ブロックです。

<log4net>
    <root>
      <level value="DEBUG" />
    </root>
    <logger name="AffectivExcitementShortTermScore">
      <level value="DEBUG" />
      <appender-ref ref="AffectivExcitementShortTermScore" />
    </logger>

    <logger name="AffectivExcitementLongTermScore">
      <level value="DEBUG" />
      <appender-ref ref="AffectivExcitementLongTermScore" />
    </logger>


    <logger name="AffectivEngagementBoredomScore">
      <level value="DEBUG" />
      <appender-ref ref="AffectivEngagementBoredomScore" />
    </logger>

    <logger name="AffectivFrustrationScore">
      <level value="DEBUG" />
      <appender-ref ref="AffectivFrustrationScore" />
    </logger>
    <logger name="AffectivMeditationScore">
      <level value="DEBUG" />
      <appender-ref ref="AffectivMeditationScore" />
    </logger>

    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
      <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <param name="File" value="C:\temp\emotiv_log.txt" />
      <param name="AppendToFile" value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="10MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%-5p%d{yyyy-MM-dd hh:mm:ss} – %m%n" />
      </layout>
    </appender>

    <appender name="AffectivExcitementShortTermScore" type="log4net.Appender.FileAppender">
      <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <file type="log4net.Util.PatternString" value="C:\\logs\\AffectivExcitementShortTermScore.csv">
      </file>
      <appendToFile value="true" />
      <layout type="DataMind.CsvPatternLayout, DataMind">
        <header value="DateTime,SystemUpTime,Value,EventTimer&#xD;&#xA;" />
        <conversionPattern value="%date{M/d/yyyy H:mm:ss.fff}%newfield%property{SystemUpTime}%newfield%property{Value}%newfield%property{EventTimer}%endrow" />
      </layout>
      <filter type="log4net.Filter.PropertyFilter">
        <Key value="Version" />
        <StringToMatch value="1" />
      </filter>
    </appender>

    <appender name="AffectivExcitementLongTermScore" type="log4net.Appender.FileAppender">
      <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <file type="log4net.Util.PatternString" value="C:\\logs\\AffectivExcitementLongTermScore.csv">
      </file>
      <appendToFile value="true" />
      <layout type="DataMind.CsvPatternLayout, DataMind">
        <header value="DateTime,SystemUpTime,Value,EventTimer&#xD;&#xA;" />
        <conversionPattern value="%date{M/d/yyyy H:mm:ss.fff}%newfield%property{SystemUpTime}%newfield%property{Value}%newfield%property{EventTimer}%endrow" />
      </layout>
      <filter type="log4net.Filter.PropertyFilter">
        <Key value="Version" />
        <StringToMatch value="1" />
      </filter>
    </appender>
    <appender name="AffectivEngagementBoredomScore" type="log4net.Appender.FileAppender">
      <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <file type="log4net.Util.PatternString" value="C:\\logs\\AffectivEngagementBoredomScore.csv">
      </file>
      <appendToFile value="true" />
      <layout type="DataMind.CsvPatternLayout, DataMind">
        <header value="DateTime,SystemUpTime,Value,EventTimer&#xD;&#xA;" />
        <conversionPattern value="%date{M/d/yyyy H:mm:ss.fff}%newfield%property{SystemUpTime}%newfield%property{Value}%newfield%property{EventTimer}%endrow" />
      </layout>
      <filter type="log4net.Filter.PropertyFilter">
        <Key value="Version" />
        <StringToMatch value="1" />
      </filter>
    </appender>

    <appender name="AffectivFrustrationScore" type="log4net.Appender.FileAppender">
      <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <file type="log4net.Util.PatternString" value="C:\\logs\\AffectivFrustrationScore.csv">
      </file>
      <appendToFile value="true" />
      <layout type="DataMind.CsvPatternLayout, DataMind">
        <header value="DateTime,SystemUpTime,Value,EventTimer&#xD;&#xA;" />
        <conversionPattern value="%date{M/d/yyyy H:mm:ss.fff}%newfield%property{SystemUpTime}%newfield%property{Value}%newfield%property{EventTimer}%endrow" />
      </layout>
      <filter type="log4net.Filter.PropertyFilter">
        <Key value="Version" />
        <StringToMatch value="1" />
      </filter>
    </appender>

    <appender name="AffectivMeditationScore" type="log4net.Appender.FileAppender">
      <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <file type="log4net.Util.PatternString" value="C:\\logs\\AffectivMeditationScore.csv">
      </file>
      <appendToFile value="true" />
      <layout type="DataMind.CsvPatternLayout, DataMind">
        <header value="DateTime,SystemUpTime,Value,EventTimer&#xD;&#xA;" />
        <conversionPattern value="%date{M/d/yyyy H:mm:ss.fff}%newfield%property{SystemUpTime}%newfield%property{Value}%newfield%property{EventTimer}%endrow" />
      </layout>
      <filter type="log4net.Filter.PropertyFilter">
        <Key value="Version" />
        <StringToMatch value="1" />
      </filter>
    </appender>
  </log4net>

以下は、複数のアペンダーを指す GetLogger メソッドです。

public class SomeClass
{

 protected static readonly ILog log = LogManager.GetLogger(typeof(Namespace.SomeClass));
        private static readonly ILog log0 = LogManager.GetLogger("AffectivExcitementShortTermScore");
        private static readonly ILog log1 = LogManager.GetLogger("AffectivExcitementLongTermScore");
        private static readonly ILog log2 = LogManager.GetLogger("AffectivEngagementBoredomScore");
        private static readonly ILog log3 = LogManager.GetLogger("AffectivFrustrationScore");
        private static readonly ILog log4 = LogManager.GetLogger("AffectivMeditationScore");

最後に、次のようにイベントを記録します。

 log0.Info(new Log
                    {
                        SystemUpTime = FormatUpTime(_states.TimeFromStart),
                        Value = _states.AffectivExcitementShortTermScore.ToString(),
                        EventTimer = _eventTimer
                    });

                    // log longterm exictement
                    log1.Info(new Log
                    {
                        SystemUpTime = FormatUpTime(_states.TimeFromStart),
                        Value = _states.AffectivExcitementLongTermScore.ToString(),
                        EventTimer = _eventTimer
                    });

私の結果 (以下) は、ログがファイルに書き込まれていないことを常に示しています。

DateTime    SystemUpTime    Value   EventTimer
37:07.6 (null)          (null)  (null)
37:07.6 (null)          (null)  (null)
37:07.6 (null)          (null)  (null)
37:07.6 (null)          (null)  (null)
37:07.7 (null)          (null)  (null)
37:07.7 (null)          (null)  (null)

アペンダーを作成したときに、app.config ファイルで何か間違ったことをしていると思います。ルートアペンダーを1つ作成してルートレベルで参照すると機能しますが、ロガーを作成してそのようにアペンダーを参照すると、失敗するようです。私はアイデアがありません - 提案はありますか?ありがとう。

4

1 に答える 1

0

ALL の Root レベル設定を試してみてはどうですか?

赤いニシンかもしれませんが、コードがlog.INFOを使用し、構成がDEBUGを指​​定していることに注意してください。

于 2012-05-17T17:23:58.537 に答える