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

Logging Java Discussion :

[log4j] Gestion de plusieurs fichiers de logs


Sujet :

Logging Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Developpeur web/Java
    Inscrit en
    Février 2008
    Messages
    98
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Developpeur web/Java
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Février 2008
    Messages : 98
    Par défaut [log4j] Gestion de plusieurs fichiers de logs
    Bonjour,

    Mon application doit écrire dans plusieurs fichiers de logs différents pour cela j'utilise l'API log4j qui me semble la plus puissante.
    J'ai donc une classe qui me permet de d'initialiser mes loggers un pour chaque fichier cette initialisation me semble correcte. Cependant j'ai implementer une méthode getLogger permettant de me retourner le logger adéquat c'est ici que je pense qu'il y a un problème. Voici un petit peu de code pour mieux comprendre :

    pour l'initialisation de mes loggers :
    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
     
     	 static{
    		 try{  			   
                         // boucle initialisant mes loggers
    		    for(int i=0;i<ChargementProperties.getVect_codeEtablissement().size();i++){
    		    	String codeEtablissement=(String)ChargementProperties.getVect_codeEtablissement().elementAt(i);
                            log = Logger.getLogger("Logger"+codeEtablissement);
                            log.setLevel(Level.DEBUG);
                            DailyRollingFileAppender appender=new  DailyRollingFileAppender(layout,path+"logs/log-"+codeEtablissement,"'.'yyyy-MM-dd");
                            appender.activateOptions();
                            log.addAppender(appender);
                            //log ecrivant bien dans le bon fichier
                            log.debug("TEST DES LOGS pour: "+codeEtablissement);
    		    }
    	    }catch (Exception e){
    	        System.out.println(e);
    	        e.printStackTrace();
    	    }
    	 }

    Pour mon getLogger :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    	public static Logger getPLogger(String codeEtablissement) {	
    		 return Logger.getLogger("Logger"+codeEtablissement);
    	}
    Donc quand je suis dans une autre classe et je souhaite loggué je dois au préalable effectué un getLogger cependant aucune trace de log est présente dans mes fichiers ensuite.

    Si quelqu'un a une idée sur ce sujet je suis prenneur, je pense que mon getLogger n'est pas correcte puisque dans la classe d'initialisation du logger pas de problème alors que dans d'autres classes aucunes traces de logs n'apparait !

  2. #2
    Membre confirmé
    Homme Profil pro
    Developpeur web/Java
    Inscrit en
    Février 2008
    Messages
    98
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Developpeur web/Java
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Février 2008
    Messages : 98
    Par défaut
    J'ai avancé sur mon problème et j'ai pu constater qu'il y avait quelque chose qui m'avait échappé (et il y en a surement encore ...). J'ai supprimé mon code qui était en static et modifié la méthode permettant de retourner mon logger.
    Ma nouvelle méthode est donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    public static Logger getPLogger(String codeEtablissement) {
    	log = Logger.getLogger("Logger"+codeEtablissement);
    	log.setLevel(Level.DEBUG);
    	try{
    		DailyRollingFileAppender appender=new DailyRollingFileAppender(layout,path+"logs/log-"+codeEtablissement,"'.'yyyy-MM-dd");
    		appender.activateOptions();
    		log.addAppender(appender);
    	}catch(Exception e){ }
    	return log;
    }
    Grâce à cette modification les logs sont bien dans le fichier désiré mais elles sont logguées 2 à 3 fois (voir une dizaine de fois dans le pire des cas) au lieu d'une seule fois comme le veut la logique.

    Cette méthode est donc appelé d'une autre classe de la façon suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    log=PLogger.getPLogger(codeEtablissement);
    log.debug("message loggué");
    Si quelqu'un a déjà eu un problème de ce type je suis preneur de toutes idées.

  3. #3
    Membre Expert
    Avatar de Patriarch24
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Septembre 2003
    Messages
    1 047
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 047
    Par défaut
    Pour commencer, je te suggère de lire les tutos de developpez.com.
    Ensuite, je te conseille d'utiliser des fichiers de configuration pour configurer tes loggers, car non seulement tu y vois plus clair, mais tu peux les changer à l'exécution sans toucher à ton code.
    Enfin, je te conseille de masquer log4j par commons-logging (il y a un très bon tuto sur le site), mais ce n'est qu'une suggestion.

    Pour terminer et répondre à ta question, pour écrire dans plusieurs fichiers, tu dois avoir plusieurs appender. Ainsi tu pourras écrire les mêmes données dans deux fichiers simultanément (ajout des deux appenders au même logger) ou écrire les données dans un seul fichier (ajout de chaque appender dans un logger différent).

    Bon courage !

  4. #4
    Membre confirmé
    Homme Profil pro
    Developpeur web/Java
    Inscrit en
    Février 2008
    Messages
    98
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Developpeur web/Java
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Février 2008
    Messages : 98
    Par défaut
    Merci pour ta réponse !

    J'avais déjà lu le tuto sur log4j. Malgré qu'il soit complet il faut il faut avouer que la gestion de deux loggers n'est pas pas flagrante !

    Pour ce qui est de commons-logging je vais m'y pencher de plus près !



    Voila j'avais trouvé ce code qui semble fonctionner mais j'ai l'impression que c'est un peu de la bidouille !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    public static Logger getPLogger(String codeEtablissement) {
            LogManager.resetConfiguration();
    	log = Logger.getLogger("Logger"+codeEtablissement);
    	log.setLevel(Level.DEBUG);
    	try{
    		DailyRollingFileAppender appender=new DailyRollingFileAppender(layout,path+"logs/log-"+codeEtablissement,"'.'yyyy-MM-dd");
    		appender.activateOptions();
    		log.addAppender(appender);
    	}catch(Exception e){ }
    	return log;
    }
    Donc je sais pas ce que tu en penses ?

  5. #5
    Membre Expert
    Avatar de Patriarch24
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Septembre 2003
    Messages
    1 047
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 047
    Par défaut
    Comme je te l'ai dit, préfère utiliser les fichiers de configuration, cela évite les constructions de loggers dans ton code

  6. #6
    Membre confirmé
    Homme Profil pro
    Developpeur web/Java
    Inscrit en
    Février 2008
    Messages
    98
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Developpeur web/Java
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Février 2008
    Messages : 98
    Par défaut
    Ok! je te remercie et je vais me pencher sur la question de faire un fichier properties qui à l'air tu as raison plus efficace.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Log4J] Configuration pour plusieurs fichiers de log
    Par erara22 dans le forum Logging
    Réponses: 0
    Dernier message: 20/09/2011, 19h54
  2. [Log4j] Externaliser nom du fichier de log
    Par JnJp28 dans le forum Logging
    Réponses: 1
    Dernier message: 08/01/2008, 18h15
  3. [log4j]Changer dynamiquement le fichier de log
    Par caro_a dans le forum Logging
    Réponses: 1
    Dernier message: 24/11/2007, 11h44
  4. Réponses: 2
    Dernier message: 14/06/2006, 11h53
  5. Réponses: 8
    Dernier message: 06/07/2004, 14h17

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