2017-06-12 59 views
2

我正在开发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上。

回答

0

研究发现,非常漂亮,有效的解决方案:https://github.com/NLog/NLog.Elmah/

要安装,

  1. Install-Package NLog.Elmah
  2. Update-Package 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与目标:

[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... 
    } 
} 

您也可以扔属性的基础控制器/课程并涵盖您的所有应用程序。

+0

我这样做确切,但没有任何记录到Elmah(elmah日志记录工程和nlog日志记录到一个文本文件工作,虽然)..我错过了什么? – benpage

+0

@benpage,你尝试过这里的步骤:https://github.com/NLog/NLog.Elmah/? – Alex

+0

是的,我当然没有.. – benpage

相关问题