Je travaille sur une application ASP.NET MVC 5 dans Visual Studio 2015. Nous utilisons NLog d'écrire des erreurs et d'autres informations à la base de données dans nos try/catch
blocs. Cependant, il serait bon d'implémenter également ELMAH.MVC, de sorte que toutes les exceptions non interceptées soient interceptées/consignées et que l'utilisateur soit redirigé vers une page conviviale.Elmah.MVC + NLog - stocker toutes les erreurs dans un seul endroit
Voici notre structure de table NLog; notez que ApplicationId
n'est pas équivalent à Application
sur le tableau ELMAH_Error
; les gens demandent des choses à travers l'application, et c'est l'identifiant que nous attribuons quand ils commencent le processus. Et RouteId
n'est pas une route 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 pour la table de ELMAH ressemble à ceci (de 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]
Est-il possible d'avoir la table ELMAH_Error
contiennent les colonnes supplémentaires se trouvent sur la table NLog Log
, ou vice versa? Comment puis-je écrire des erreurs de NLog à la table ELMAH?
Merci.
Mise à jour 1: Came à travers cela: https://github.com/ccellar/nlog-elmah-target, mais il manque de documentation sur la façon dont vous l'utilisez. Est-ce que cela redirigerait toutes les exceptions NLog vers ELMAH?
Mise à jour 2: Un related question a été interrogé sur l'ajout du dictionnaire Exception.Data
à ELMAH. De cette façon, n'importe quel nombre de paires clé/valeur peut être ajouté à ce qu'Elma a stocké. De cette façon, toutes les données stockées avec NLog seront stockées sur ELMAH.
Je fais cela exactement mais rien ne se connecte à Elmah (la journalisation d'elmah fonctionne et la journalisation de nlog dans un fichier de texte marche, cependant) ... est-ce que je manque quelque chose? – benpage
@benpage, avez-vous essayé les étapes ici: https://github.com/NLog/NLog.Elmah/? – Alex
oui j'ai certainement fait .. – benpage