我正在開發Visual Studio 2015中的ASP.NET MVC 5應用程序。我們使用NLog在我們的try/catch
塊中向數據庫中寫入一些錯誤和其他信息。但是,如果還執行ELMAH.MVC,這樣會很好,因此任何/所有未捕獲的異常都會被捕獲/記錄,並且用戶會重定向到一個友好的頁面。Elmah.MVC + NLog - 將所有錯誤存儲在一個地方
這是我們的NLog表結構;請注意0與ELMAH_Error
表中的Application
不等價;人們通過應用程序申請事物,這是我們在開始流程時分配的ID。而RouteId
不是一個MVC路線。
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爲ELMAH的表看起來像這樣(從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: A related question已詢問將Exception.Data
字典添加到ELMAH。這樣,可以將任意數量的鍵/值對添加到Elmah存儲的內容中。這樣,現在用NLog存儲的所有數據都將存儲在ELMAH上。
我這樣做確切,但沒有任何記錄到Elmah(elmah日誌記錄工程和nlog日誌記錄到一個文本文件工作,雖然)..我錯過了什麼? – benpage
@benpage,你嘗試過這裏的步驟:https://github.com/NLog/NLog.Elmah/? – Alex
是的,我當然沒有.. – benpage