2017-06-12 4 views
2

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.

Répondre

0

trouvé une solution qui fonctionne très bien: https://github.com/NLog/NLog.Elmah/

Pour installer,

  1. Install-Package NLog.Elmah
  2. Update-Package NLog
  3. J'ai aussi installé le paquet NLog.Web, mais ne doit pas pour cela.
  4. Modifier NLog.config pour inclure:
<targets><target name="target1" xsi:type="Elmah" LogLevelAsType"false" /></targets> 
    <rules><logger name="*" minlevel="Info" writeTo="target1" /></rules> 

Maintenant décorer ne importe quel contrôleur/classe qui utilise NLog avec la cible:

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

Vous pouvez également jeter l'attribut sur un contrôleur de base/class et couvre toute votre application.

+0

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

+0

@benpage, avez-vous essayé les étapes ici: https://github.com/NLog/NLog.Elmah/? – Alex

+0

oui j'ai certainement fait .. – benpage