Elmah.MVC + NLog - 将所有错误存储在一个地方
Elmah.MVC + NLog - store all errors in one place
我正在 Visual Studio 2015 年开发一个 ASP.NET MVC 5 应用程序。我们使用 NLog 在 try/catch
块中将一些错误和其他信息写入数据库。但是,最好也实现 ELMAH.MVC,以便 any/all 未捕获的异常得到 caught/logged 并将用户重定向到一个友好的页面。
这是我们的 NLog table 结构;请注意 ApplicationId
不等同于 ELMAH_Error
table 上的 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]
ELMAH 的 table 的 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
table 包含在 NLog Log
table 上找到的附加列,反之亦然?如何将错误从 NLog 写入 ELMAH table?
谢谢。
更新 1: 遇到了这个:https://github.com/ccellar/nlog-elmah-target,但它缺少有关如何使用它的任何文档。这会将所有 NLog 异常重定向到 ELMAH 吗?
更新 2: related question 被问及将 Exception.Data
词典添加到 ELMAH。这样,可以将任意数量的 key/value 对添加到 Elmah 存储的内容中。这样,现在用 NLog 存储的所有数据都将存储在 ELMAH 上。
找到了一个非常有效的解决方案:https://github.com/NLog/NLog.Elmah/
要安装,
Install-Package NLog.Elmah
Update-Package NLog
- 我还安装了 NLog.Web 包,但这不是必需的。
- 修改 NLog.config 以包括:
<targets><target name="target1" xsi:type="Elmah" LogLevelAsType"false" /></targets>
<rules><logger name="*" minlevel="Info" writeTo="target1" /></rules>
现在只需装饰任何使用 NLog 的 controller/class 目标:
[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...
}
}
你也可以把属性扔到一个基础上controller/class,覆盖你所有的应用。
我正在 Visual Studio 2015 年开发一个 ASP.NET MVC 5 应用程序。我们使用 NLog 在 try/catch
块中将一些错误和其他信息写入数据库。但是,最好也实现 ELMAH.MVC,以便 any/all 未捕获的异常得到 caught/logged 并将用户重定向到一个友好的页面。
这是我们的 NLog table 结构;请注意 ApplicationId
不等同于 ELMAH_Error
table 上的 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]
ELMAH 的 table 的 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
table 包含在 NLog Log
table 上找到的附加列,反之亦然?如何将错误从 NLog 写入 ELMAH table?
谢谢。
更新 1: 遇到了这个:https://github.com/ccellar/nlog-elmah-target,但它缺少有关如何使用它的任何文档。这会将所有 NLog 异常重定向到 ELMAH 吗?
更新 2: related question 被问及将 Exception.Data
词典添加到 ELMAH。这样,可以将任意数量的 key/value 对添加到 Elmah 存储的内容中。这样,现在用 NLog 存储的所有数据都将存储在 ELMAH 上。
找到了一个非常有效的解决方案:https://github.com/NLog/NLog.Elmah/
要安装,
Install-Package NLog.Elmah
Update-Package NLog
- 我还安装了 NLog.Web 包,但这不是必需的。
- 修改 NLog.config 以包括:
<targets><target name="target1" xsi:type="Elmah" LogLevelAsType"false" /></targets>
<rules><logger name="*" minlevel="Info" writeTo="target1" /></rules>
现在只需装饰任何使用 NLog 的 controller/class 目标:
[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...
}
}
你也可以把属性扔到一个基础上controller/class,覆盖你所有的应用。