sql-server - Elmah.MVC + NLog - 将所有错误存储在一个地方

标签 sql-server asp.net-mvc nlog elmah elmah.mvc

我正在 Visual Studio 2015 中开发 ASP.NET MVC 5 应用程序。我们使用 NLog 在 try/catch block 中将一些错误和其他信息写入数据库。但是,最好也实现 ELMAH.MVC ,以便捕获/记录任何/所有未捕获的异常,并将用户重定向到友好的页面。

这是我们的 NLog 表结构;请注意 ApplicationId 不等同于 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]

ELMAH 表的 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: A related question已被问及如何将 Exception.Data 字典添加到 ELMAH。这样,可以将任意数量的键/值对添加到 Elmah 存储的内容中。这样,现在使用 NLog 存储的所有数据都将存储在 ELMAH 上。

最佳答案

找到了一个非常有效的解决方案:https://github.com/NLog/NLog.Elmah/

安装,

  1. 安装包 NLog.Elmah
  2. 更新包 NLog
  3. 我还安装了 NLog.Web 包,但这不是必需的。
  4. 修改 NLog.config 以包括:
<targets><target name="target1" xsi:type="Elmah" LogLevelAsType"false" /></targets>
    <rules><logger name="*" minlevel="Info" writeTo="target1" /></rules>

现在只需用目标装饰任何使用 NLog 的 Controller /类:

[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 /类上并覆盖您的所有应用程序。

关于sql-server - Elmah.MVC + NLog - 将所有错误存储在一个地方,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44506925/

相关文章:

asp.net-mvc - .NET MVC-从另一个 Controller Action 调用一个 Controller Action

c# - 将数据从 Controller 传递到 View - MVC

nlog - 使用 Nlog 将结构化日志写入 Google Stackdriver

mysql 和 unicode 字符

sql-server - 如何对多对多表进行级联删除

c# - SQL 表到 JSON 文件

c# - NLog LogManager.GetLogger(String, Type) 重载的目的是什么

sql - 1 个 Sql Azure 数据库中可以有多少个表

javascript - 在 KnockoutJS 中很难绑定(bind)数组

c# - 如何记录复杂的同步过程?