IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

[LOG4NET]Logger dans un fichier différent pour chaque instance d'une classe


Sujet :

C#

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 196
    Points : 94
    Points
    94
    Par défaut [LOG4NET]Logger dans un fichier différent pour chaque instance d'une classe
    Bonjour,
    J'ai une appli qui utilise log4net pour le logging.
    J'ai un fichier de conf XML qui permet la configuration des différents logger qui marche sans soucis. Tous les loggers de mon appli log dans un fichier mon_appli.log.

    Là ou je ne m'en tire pas, c'est pour avoir un logger qui log dans un fichier différent pour chaque instance d'une de mes classes. J'ai une classe Task que j'instancie plusieurs fois. Je voudrais qu'à chaque fois que j'instancie ma classe, le logger qu'elle contient journalise dans un fichier spécifique.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
     class Task 
        {       
            private ILog logger = null;
            private string m_name;
     
            public Task(string name){
              this.m_name = name;
              FileAppender appender = new FileAppender();
              appender.Layout = new PatternLayout("%d [%t] %-5p %c %m%n");
              appender.File = taskId + ".log";
              appender.AppendToFile = true;
              appender.Name = "File";
              appender.Threshold = log4net.Core.Level.All;
              appender.ActivateOptions();
     
              logger = LogManager.GetLogger(this.m_name);
              ((log4net.Repository.Hierarchy.Logger)logger.Logger).AddAppender(appender);
            }
     
            public void test(){
              logger.Info("test");
            }
    ...
    Le fichier nom_de_ma_tache.log est bien créé, et les logs s'y insère correctement. Par contre, là ou c'est moins bien, c'est que je retrouve aussi le logs dans le fichier de log principal mon_appli.log...

    Est ce que quelqu'un aurait une chtite idée de comment faire???
    Merci beaucoup!!!

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 196
    Points : 94
    Points
    94
    Par défaut
    Bonjour,
    J'ai essayé à tout hazard de supprimer tous les appenders de mon logger, même résultat
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     logger = LogManager.GetLogger(this.m_name);        ((log4net.Repository.Hierarchy.Logger)logger.Logger).RemoveAllAppenders();
    ((log4net.Repository.Hierarchy.Logger)logger.Logger).AddAppender(appender);
    Quelqu'un a une piste?

    Merci beaucoup !!!

  3. #3
    Expert éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 141
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 141
    Points : 12 242
    Points
    12 242
    Par défaut
    Franchement, il est très intéressant d'avoir un seul fichier de log. Cela permet d'avoir une vue historique clair et univoque.
    Après, il suffit d'avoir un petit client qui filtre les lignes de logs selon des critères pour n'avoir que les flux qui vous intéressent à un moment donné.

  4. #4
    Expert confirmé

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Septembre 2006
    Messages
    3 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 580
    Points : 5 195
    Points
    5 195
    Par défaut
    salut

    ne peux tu utiliser le Trace et les listener pour faire celà ? ainsi dans chaque classe, tu fais du Trace.Writeline(ton message à logguer) et derrière, tu auras un TraceListener qui mettra tout celà dans un fichier.

    Chez moi, ce genre de technique fonctionne à la perfection
    The Monz, Toulouse
    Expertise dans la logistique et le développement pour
    plateforme .Net (Windows, Windows CE, Android)

  5. #5
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 1
    Points : 1
    Points
    1
    Par défaut
    J'ai eu le même genre de chose à faire.

    En fait c'est relativement simple, si tu utilises le fichier de configuration XML, il te faut supprimer le noeud Root si il est présent car Log4Net log à travers tes différents logger et en plus utilise le noeud root si tu logues des messages de type info et que ton noeud root utilise le niveau info par défaut (logue en double).
    Il te faut également bien spécifier le nom de tes logger lors de chaque log .

Discussions similaires

  1. Réponses: 6
    Dernier message: 27/06/2014, 14h54
  2. Réponses: 5
    Dernier message: 31/05/2010, 09h51
  3. Réponses: 0
    Dernier message: 06/10/2009, 13h02
  4. Réponses: 8
    Dernier message: 13/07/2009, 08h57
  5. otpion de jvm différentes pour chaque instance Jboss
    Par germain35 dans le forum Wildfly/JBoss
    Réponses: 1
    Dernier message: 26/01/2009, 10h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo