log4j - Niveaux de journalisation

le org.apache.log4j.Levelles niveaux. Vous pouvez également définir vos niveaux personnalisés en sous-classant lesLevel classe.

Niveau La description
TOUT Tous les niveaux, y compris les niveaux personnalisés.
DÉBOGUER Désigne les événements d'information à granularité fine les plus utiles pour déboguer une application.
INFO Désigne des messages d'information qui mettent en évidence la progression de l'application à un niveau grossier.
PRÉVENIR Désigne les situations potentiellement dangereuses.
ERREUR Désigne les événements d'erreur susceptibles de permettre à l'application de continuer à s'exécuter.
FATAL Désigne des événements d'erreur très graves qui conduiront vraisemblablement l'application à abandonner.
DE Le rang le plus élevé possible et est destiné à désactiver la journalisation.
TRACE Désigne des événements d'information plus fins que le DEBUG.

Comment fonctionnent les niveaux?

Une demande de journal de niveau p dans un enregistreur avec niveau q est enabledsi p> = q. Cette règle est au cœur de log4j. Il suppose que les niveaux sont ordonnés. Pour les niveaux standard, nous avons ALL <DEBUG <INFO <WARN <ERROR <FATAL <OFF.

L'exemple suivant montre comment nous pouvons filtrer tous nos messages DEBUG et INFO. Ce programme utilise la méthode d'enregistrement setLevel (Level.X) pour définir un niveau d'enregistrement souhaité:

Cet exemple afficherait tous les messages sauf Debug et Info:

import org.apache.log4j.*;

public class LogClass {
   private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
   
   public static void main(String[] args) {
      log.setLevel(Level.WARN);

      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

Lorsque vous compilez et exécutez le LogClass programme, il générerait le résultat suivant -

Warn Message!
Error Message!
Fatal Message!

Définition des niveaux à l'aide du fichier de configuration

log4j vous fournit un paramètre de niveau basé sur un fichier de configuration qui vous évite de modifier le code source lorsque vous souhaitez modifier le niveau de débogage.

Voici un exemple de fichier de configuration qui effectuerait la même tâche que nous l'avons fait en utilisant le log.setLevel(Level.WARN) méthode dans l'exemple ci-dessus.

# Define the root logger with appender file
log = /usr/home/log4j
log4j.rootLogger = WARN, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=${log}/log.out

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

Utilisons maintenant notre programme suivant -

import org.apache.log4j.*;

public class LogClass {

   private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
   
   public static void main(String[] args) {
   
      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

Maintenant, compilez et exécutez le programme ci-dessus et vous obtiendrez le résultat suivant dans /usr/home/log4j/log.out fichier -

Warn Message!
Error Message!
Fatal Message!