Visual Studio 2015でASP.NET MVC 5アプリケーションを使用しています.ブロックでNLogを使用していくつかのエラーやその他の情報をデータベースに書き込みます。しかし、ELMAH.MVCも実装すると良いでしょう。その結果、捕捉されなかった例外がキャッチ/ロギングされ、ユーザーはフレンドリーなページにリダイレクトされます。Elmah.MVC + NLog - すべてのエラーを1か所に保存します。
NLogテーブルの構造は次のとおりです。 ApplicationId
はELMAH_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に保存されます。非常にうまく機能するソリューションが見つかり
私はこれを正確に行いますが、Elmahにログを記録するものはありません(elmahのログ出力とテキストファイルへのログ出力は動作します)。何か不足していますか? – benpage
@benpage、ここで手順を試しましたか:https://github.com/NLog/NLog.Elmah/? – Alex
はい私は確かに.. – benpage