2017-06-12 1 views
2

Visual Studio 2015でASP.NET MVC 5アプリケーションを使用しています.ブロックでNLogを使用していくつかのエラーやその他の情報をデータベースに書き込みます。しかし、ELMAH.MVCも実装すると良いでしょう。その結果、捕捉されなかった例外がキャッチ/ロギングされ、ユーザーはフレンドリーなページにリダイレクトされます。Elmah.MVC + NLog - すべてのエラーを1か所に保存します。

NLogテーブルの構造は次のとおりです。 ApplicationIdELMAH_ErrorテーブルのApplicationに相当しません。人々はアプリを介して物事を申請し、これはプロセスを開始するときに割り当てたIDです。 RouteIdはMVCルートではありません。 ELMAHのテーブルの

CREATE TABLE [dbo].[Log](
    [Id] [int] IDENTITY(1,1) NOT NULL, 
    [ApplicationId] [int] NULL, 
    [RouteId] [int] NULL, 
    [MachineName] [varchar](50) NULL, 
    [TimeStamp] [datetime2](7) NULL, 
    [LogLevel] [varchar](5) NULL, 
    [Logger] [nvarchar](max) NULL, 
    [Message] [nvarchar](max) NULL, 
    [Exception] [nvarchar](max) NULL, 
    [StackTrace] [nvarchar](max) NULL, 
CONSTRAINT [PK_Log] PRIMARY KEY CLUSTERED 
(
    [Id] ASC 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 

SQL は(the script hereから)次のようになります。

CREATE TABLE [dbo].[ELMAH_Error] 
(
    [ErrorId]  UNIQUEIDENTIFIER NOT NULL, 
    [Application] NVARCHAR(60) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
    [Host]  NVARCHAR(50) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
    [Type]  NVARCHAR(100) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
    [Source]  NVARCHAR(60) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
    [Message]  NVARCHAR(500) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
    [User]  NVARCHAR(50) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
    [StatusCode] INT NOT NULL, 
    [TimeUtc]  DATETIME NOT NULL, 
    [Sequence] INT IDENTITY (1, 1) NOT NULL, 
    [AllXml]  NTEXT COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL 
) 
ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 

それはELMAH_Error表はその逆NLog Logテーブルで見つかった追加の列が含まれている、または持っていることは可能ですか? NLogからELMAHテーブルにエラーを書き込むにはどうすればよいですか?

ありがとうございます。

更新1:これには、https://github.com/ccellar/nlog-elmah-targetがありますが、使用方法に関するドキュメントはありません。これはすべてのNLog例外をELMAHにリダイレクトしますか?

更新2:related questionは、Exception.Data辞書をELMAHに追加することについて質問されました。この方法で、任意の数のキーと値のペアをエルマが保存したものに追加できます。このようにして、NLogで現在保存されているすべてのデータがELMAHに保存されます。非常にうまく機能するソリューションが見つかり

答えて

0

:インストールするにはhttps://github.com/NLog/NLog.Elmah/

を、

  1. Install-Package NLog.Elmah
  2. Update-Package NLog
  3. 私はまたNLog.Webパッケージをインストールしたのですが、これは必要ありません。
<targets><target name="target1" xsi:type="Elmah" LogLevelAsType"false" /></targets> 
    <rules><logger name="*" minlevel="Info" writeTo="target1" /></rules> 

を今だけターゲットにNLogを使用して任意のコントローラ/クラスを飾る:

[Target("Elmah")] 
public class HomeController : Controller 
{ 
    private static Logger _logger = LogManager.GetCurrentClassLogger(); 
    public ActionResult Index() 
    { 
     // Other code... 

     var logEvent = new LogEventInfo(LogLevel.Info, _logger.Name, "Some information..."); 
     _logger.Log(logEvent); 

     // Other code... 
    } 
} 

ます。また、ベースコントローラ上の属性を投げることができます含めるように

  • 修正NLog.config /クラスとすべてのアプリケーションをカバーします。

  • +0

    私はこれを正確に行いますが、Elmahにログを記録するものはありません(elmahのログ出力とテキストファイルへのログ出力は動作します)。何か不足していますか? – benpage

    +0

    @benpage、ここで手順を試しましたか:https://github.com/NLog/NLog.Elmah/? – Alex

    +0

    はい私は確かに.. – benpage

    関連する問題