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

时间:2017-06-12 19:03:03

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

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

这是我们的NLog表格结构;请注意,ApplicationId不等同于Application表中的ELMAH_Error;人们通过应用程序申请内容,这是我们在启动流程时分配的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 :系统已询问related question是否已将Exception.Data字典添加到ELMAH。这样,可以将任意数量的键/值对添加到Elmah存储的内容中。这样,现在与NLog一起存储的所有数据都将存储在ELMAH上。

1 个答案:

答案 0 :(得分:1)

找到一个非常好用的解决方案:https://github.com/NLog/NLog.Elmah/

要安装,

  1. Install-Package NLog.Elmah
  2. Update-Package NLog
  3. 我还安装了NLog.Web软件包,但这不是必需的。
  4. 修改NLog.config以包含:
  5. <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...
        }
    }
    

    您还可以将该属性放在基本控制器/类上,并覆盖所有应用程序。