4

シンプルなコンソールアプリがあります。log4net nuget パッケージと log4net raygun nuget パッケージをダウンロードしました: https://www.nuget.org/packages/log4net.Raygun/。例外と情報メッセージをログに記録するようにアプリをセットアップしましたが、それらはログ ファイルに記録されますが、raygun ダッシュボードには記録されず、raygun.io からの電子メールも取得されません。私は何を間違っていますか?

private static readonly ILog Log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);

private static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
{
    Log.Error(e);
}

private static void Main(string[] args)
{
    XmlConfigurator.Configure();

    // Unhandled exceptions
    AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException;
throw new Exception("test exception");

}

Web.Config:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <!-- log4net -->
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>

  <log4net>
    <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="ErrorLog//ErrorLog.txt" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="2" />
      <maximumFileSize value="1MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%d [%t] %-5p %c %m%n" />
      </layout>
    </appender>

    <appender name="RaygunAppender" type="log4net.Raygun.RaygunAppender, log4net.Raygun">
      <threshold value="DEBUG" />
      <apiKey value="MY SUPER AWESOME KEY HERE" />
      <!-- Attempt to send errors to raygun 15 times -->
      <retries value="15" />
      <!-- Wait 1 minute between retry attempts -->
      <timeBetweenRetries value="00:01:00" />
      <!-- Toggles whether to only send exceptions to raygun, or to also send messages logged to ERROR -->
      <onlySendExceptions value="false" />
      <!-- Optional filters for filtering exceptions and messages before sending to raygun -->
      <!--<exceptionFilter value="SomeOtherAssembly.SensitiveInformationMessageFilter, SomeOtherAssembly" />
      <renderedMessageFilter value="SomeOtherAssembly.SensitiveInformationMessageFilter, SomeOtherAssembly" />-->
    </appender>

    <root>
      <level value="ALL" />
      <appender-ref ref="LogFileAppender" />
      <appender-ref ref="RaygunAppender" />
    </root>
  </log4net>

    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
  <runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
      <dependentAssembly>
        <assemblyIdentity name="log4net" publicKeyToken="669e0ddf0bb1aa2a" culture="neutral" />
        <bindingRedirect oldVersion="0.0.0.0-1.2.13.0" newVersion="1.2.13.0" />
      </dependentAssembly>
    </assemblyBinding>
  </runtime>
</configuration>

編集:デバッグと「XmlConfigurator.Configure();」を追加しました。これは私が得たものです(ただし、Raygun.ioダッシュボードにはまだエラーは表示されません):

...
log4net: RaygunAppender: Building Raygun message
log4net: RaygunAppender: Resolving application assembly
log4net: RaygunAppender: No exception object found in error, creating raygun error message from the rendered message and calling class
log4net: RaygunAppender: Sending Raygun message in a background task. Retries: '15', TimeBetweenRetries: '00:01:00'
4

2 に答える 2

4

構成を読み取るように log4net に指示する必要があります。メイン メソッドに次の行を追加します。

log4net.Config.XmlConfigurator(Watch = true);

または、次の属性を assamblyinfo.cs に追加します。

[assembly: log4net.Config.XmlConfigurator(Watch = true)]

それが機能しない場合は、log4net 内部デバッグを有効にして、log4net 内部コードで何が起こっているかを確認できます。

<configuration>
...
    <appSettings>
        <add key="log4net.Internal.Debug" value="true"/>
    </appSettings>

...

    <system.diagnostics>
        <trace autoflush="true">
            <listeners>
                <add 
                    name="textWriterTraceListener" 
                    type="System.Diagnostics.TextWriterTraceListener" 
                    initializeData="C:\tmp\log4net.txt" />
            </listeners>
        </trace>
    </system.diagnostics>
</configuration>

Log4net FAQ

于 2015-02-17T09:35:44.120 に答える
2

いくつかの提案。ハンドラーは、イベントの代わりに、ログ記録のためにオブジェクトを log4net に渡しCurrentDomain_UnhandledExceptionています。例外を処理するには、おそらく次のようなものが必要です。UnhandledExceptionEventArgsExceptionObjectlog4net.Raygun

private static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
{
    Log.Error(e.ExceptionObject);
}

あなたが抱えているもう1つの問題は、デフォルトlog4net.RaygunではバックグラウンドタスクでRaygunにメッセージを送信することです. シンプルなコンソール アプリでは、バックグラウンド タスクが完了する前にアプリケーションが終了してアンロードされるため、メッセージが実際に送信されることはありません。次の設定をアペンダー構成に追加することで、エラーのバックグラウンド送信を無効にすることができます。

<appender name="RaygunAppender" type="log4net.Raygun.RaygunAppender, log4net.Raygun">
...
    <sendInBackground value="false" />
...
</appender>
于 2015-02-18T18:05:39.440 に答える