log4j - Guide rapide

log4j est un framework de journalisation (API) fiable, rapide et flexible écrit en Java, distribué sous la licence logicielle Apache.

log4j a été porté dans les langages C, C ++, C #, Perl, Python, Ruby et Eiffel.

log4j est hautement configurable via des fichiers de configuration externes au moment de l'exécution. Il voit le processus de journalisation en termes de niveaux de priorités et offre des mécanismes pour diriger les informations de journalisation vers une grande variété de destinations, telles qu'une base de données, un fichier, une console, UNIX Syslog, etc.

log4j a trois composants principaux:

  • loggers: Responsable de la capture des informations de journalisation.

  • appenders: Responsable de la publication des informations de journalisation vers diverses destinations préférées.

  • layouts: Responsable du formatage des informations de journalisation dans différents styles.

Histoire de log4j

  • Lancé au début de 1996 en tant qu'API de traçage pour le projet EU SEMPER (Secure Electronic Marketplace for Europe).

  • Après d'innombrables améliorations et plusieurs incarnations, l'API initiale a évolué pour devenir log4j, un package de journalisation populaire pour Java.

  • Le package est distribué sous la licence logicielle Apache, une licence open source à part entière certifiée par l'initiative open source.

  • La dernière version de log4j, y compris son code source complet, ses fichiers de classe et sa documentation, est disponible sur http://logging.apache.org/log4j/.

Fonctionnalités de log4j

  • C'est thread-safe.

  • Il est optimisé pour la vitesse.

  • Il est basé sur une hiérarchie de consignateurs nommés.

  • Il prend en charge plusieurs appenders de sortie par enregistreur.

  • Il prend en charge l'internationalisation.

  • Il n'est pas limité à un ensemble prédéfini d'installations.

  • Le comportement de journalisation peut être défini lors de l'exécution à l'aide d'un fichier de configuration.

  • Il est conçu pour gérer les exceptions Java dès le début.

  • Il utilise plusieurs niveaux, à savoir ALL, TRACE, DEBUG, INFO, WARN, ERROR et FATAL.

  • Le format de la sortie du journal peut être facilement modifié en étendant la classe Layout .

  • La cible de la sortie du journal ainsi que la stratégie d'écriture peuvent être modifiées par les implémentations de l'interface Appender.

  • C'est un arrêt en cas de panne. Cependant, bien qu'il s'efforce certainement d'assurer la livraison, log4j ne garantit pas que chaque instruction de journal sera livrée à sa destination.

Avantages et inconvénients de la journalisation

La journalisation est une composante importante du développement logiciel. Un code de journalisation bien écrit offre un débogage rapide, une maintenance facile et un stockage structuré des informations d'exécution d'une application.

L'exploitation forestière a également ses inconvénients. Cela peut ralentir une application. S'il est trop verbeux, cela peut provoquer une cécité de défilement. Pour atténuer ces problèmes, log4j est conçu pour être fiable, rapide et extensible.

Étant donné que la journalisation est rarement l'objectif principal d'une application, l'API log4j s'efforce d'être simple à comprendre et à utiliser.

Le package API log4j est distribué sous la licence logicielle Apache, une licence open source à part entière certifiée par l'initiative open source.

La dernière version de log4j, y compris le code source complet, les fichiers de classe et la documentation, est disponible sur http://logging.apache.org/log4j/.

Pour installer log4j sur votre système, téléchargez apache-log4j-xxxtar.gz à partir de l'URL spécifiée et suivez les étapes ci-dessous.

Étape 1

Décompressez et décompressez le fichier téléchargé dans le répertoire / usr / local / comme suit:

$ gunzip apache-log4j-1.2.15.tar.gz
$ tar -xvf apache-log4j-1.2.15.tar
apache-log4j-1.2.15/tests/input/
apache-log4j-1.2.15/tests/input/xml/
apache-log4j-1.2.15/tests/src/
apache-log4j-1.2.15/tests/src/java/
apache-log4j-1.2.15/tests/src/java/org/
.......................................

Lors de l'annulation du gommage, cela créerait une hiérarchie de répertoires avec un nom apache-log4j-xxx comme suit:

-rw-r--r--  1 root root   3565 2007-08-25 00:09 BUILD-INFO.txt
-rw-r--r--  1 root root   2607 2007-08-25 00:09 build.properties.sample
-rw-r--r--  1 root root  32619 2007-08-25 00:09 build.xml
drwxr-xr-x 14 root root   4096 2010-02-04 14:09 contribs
drwxr-xr-x  5 root root   4096 2010-02-04 14:09 examples
-rw-r--r--  1 root root   2752 2007-08-25 00:09 INSTALL
-rw-r--r--  1 root root   4787 2007-08-25 00:09 KEYS
-rw-r--r--  1 root root  11366 2007-08-25 00:09 LICENSE
-rw-r--r--  1 root root 391834 2007-08-25 00:29 log4j-1.2.15.jar
-rw-r--r--  1 root root    160 2007-08-25 00:09 NOTICE
-rwxr-xr-x  1 root root  10240 2007-08-25 00:27 NTEventLogAppender.dll
-rw-r--r--  1 root root  17780 2007-08-25 00:09 pom.xml
drwxr-xr-x  7 root root   4096 2007-08-25 00:13 site
drwxr-xr-x  8 root root   4096 2010-02-04 14:08 src
drwxr-xr-x  6 root root   4096 2010-02-04 14:09 tests

Étape 2

Cette étape est facultative et dépend des fonctionnalités que vous allez utiliser à partir du framework log4j. Si vous avez déjà installé les packages suivants sur votre machine, c'est très bien, sinon vous devez les installer pour que log4j fonctionne.

  • JavaMail API:La fonction de journalisation par courrier électronique de log4j nécessite l'installation de l'API Java Mail (mail.jar) sur votre machine à partir de glassfish.dev .

  • JavaBeans Activation Framework: L'API Java Mail exigera également que le cadre d'activation JavaBeans (activation.jar) soit installé sur votre machine à partir de http://java.sun.com/products/javabeans/jaf/index.jsp.

  • Java Message Service: Les fonctionnalités compatibles JMS de log4j nécessiteront que JMS et Java Naming and Directory Interface JNDI soient installés sur votre machine à partir de http://java.sun.com/products/jms.

  • XML Parser:Vous avez besoin d'un analyseur XML compatible JAXP pour utiliser log4j. Assurez-vous que Xerces.jar est installé sur votre machine depuishttp://xerces.apache.org/xerces-j/install.html.

Étape 3

Vous devez maintenant configurer le CLASSPATH et PATHvariables de manière appropriée. Ici, nous allons le définir uniquement pour le fichier log4j.xxxjar.

$ pwd
/usr/local/apache-log4j-1.2.15
$ export CLASSPATH= \
      $CLASSPATH:/usr/local/apache-log4j-1.2.15/log4j-1.2.15.jar
$ export PATH=$PATH:/usr/local/apache-log4j-1.2.15/

L'API log4j suit une architecture en couches où chaque couche fournit différents objets pour effectuer différentes tâches. Cette architecture en couches rend la conception flexible et facile à étendre à l'avenir.

Il existe deux types d'objets disponibles avec le framework log4j.

  • Core Objects:Ce sont des objets obligatoires du framework. Ils sont tenus d'utiliser le framework.

  • Support Objects:Ce sont des objets optionnels du framework. Ils prennent en charge les objets de base pour effectuer des tâches supplémentaires mais importantes.

Objets de base

Les objets principaux incluent les types d'objets suivants:

Objet Logger

La couche de niveau supérieur est le Logger qui fournit l'objet Logger. L'objet Logger est responsable de la capture des informations de journalisation et elles sont stockées dans une hiérarchie d'espace de noms.

Objet de mise en page

La couche de mise en page fournit des objets qui sont utilisés pour formater les informations de journalisation dans différents styles. Il prend en charge les objets appender avant de publier les informations de journalisation.

Les objets de mise en page jouent un rôle important dans la publication des informations de journalisation d'une manière qui soit lisible par l'homme et réutilisable.

Objet Appender

Il s'agit d'un calque de niveau inférieur qui fournit des objets Appender. L'objet Appender est responsable de la publication des informations de journalisation vers diverses destinations préférées telles qu'une base de données, un fichier, une console, UNIX Syslog, etc.

Le diagramme virtuel suivant montre les composants d'un framework log4J:

Objets de support

Il existe d'autres objets importants dans le framework log4j qui jouent un rôle vital dans le framework de journalisation:

Objet de niveau

L'objet Level définit la granularité et la priorité de toutes les informations de journalisation. Il existe sept niveaux de journalisation définis dans l'API: OFF, DEBUG, INFO, ERROR, WARN, FATAL et ALL.

Objet de filtre

L'objet Filter est utilisé pour analyser les informations de journalisation et prendre d'autres décisions quant à savoir si ces informations doivent être journalisées ou non.

Un objet Appender peut être associé à plusieurs objets Filter. Si les informations de journalisation sont transmises à un objet Appender particulier, tous les objets Filter associés à cet Appender doivent approuver les informations de journalisation avant de pouvoir être publiées sur la destination attachée.

ObjectRenderer

L'objet ObjectRenderer est spécialisé dans la fourniture d'une représentation String de différents objets passés à l'infrastructure de journalisation. Cet objet est utilisé par les objets Layout pour préparer les informations de journalisation finales.

LogManager

L'objet LogManager gère la structure de journalisation. Il est responsable de la lecture des paramètres de configuration initiaux à partir d'un fichier de configuration à l'échelle du système ou d'une classe de configuration.

Le chapitre précédent expliquait les composants de base de log4j. Ce chapitre explique comment configurer les composants principaux à l'aide d'un fichier de configuration. La configuration de log4j implique l'attribution du niveau, la définition d'Appender et la spécification des objets de mise en page dans un fichier de configuration.

Le fichier log4j.properties est un fichier de configuration log4j qui conserve les propriétés par paires clé-valeur. Par défaut, le LogManager recherche un fichier nommé log4j.properties dans leCLASSPATH.

  • Le niveau de l'enregistreur racine est défini comme DEBUG. Le DEBUG y attache l'appender nommé X.

  • Définissez l'appender nommé X comme un appender valide.

  • Définissez la mise en page de l'appender X.

Log4j.properties Syntaxe:

Voici la syntaxe du fichier log4j.properties pour un appender X:

# Define the root logger with appender X
log4j.rootLogger = DEBUG, X

# Set the appender named X to be a File appender
log4j.appender.X=org.apache.log4j.FileAppender

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

Exemple de log4j.properties

En utilisant la syntaxe ci-dessus, nous définissons ce qui suit dans le fichier log4j.properties :

  • Le niveau de l'enregistreur racine est défini comme DEBUG, l'appender DEBUG nommé FILE.

  • L'appender FILE est défini comme org.apache.log4j.FileAppender . Il écrit dans un fichier nommé "log.out" situé dans lelog annuaire.

  • Le modèle de disposition défini est % m% n , ce qui signifie que le message de journalisation imprimé sera suivi d'un caractère de nouvelle ligne.

# Define the root logger with appender file
log4j.rootLogger = DEBUG, 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

Il est important de noter que log4j prend en charge la substitution de variables de style UNIX telle que $ {variableName}.

Niveau de débogage

Nous avons utilisé DEBUG avec les deux appenders. Toutes les options possibles sont:

  • TRACE
  • DEBUG
  • INFO
  • WARN
  • ERROR
  • FATAL
  • ALL

Ces niveaux seraient expliqués dans Log4j Logging Levels .

Appenders

Apache log4j fournit des objets Appender qui sont principalement responsables de l'impression des messages de journalisation vers différentes destinations telles que les consoles, les fichiers, les sockets, les journaux d'événements NT, etc.

Chaque objet Appender a différentes propriétés qui lui sont associées, et ces propriétés indiquent le comportement de cet objet.

Propriété La description
disposition Appender utilise les objets Layout et le modèle de conversion qui leur est associé pour formater les informations de journalisation.
cible La cible peut être une console, un fichier ou un autre élément selon l'appender.
niveau Le niveau est requis pour contrôler le filtrage des messages du journal.
seuil Appender peut avoir un niveau de seuil qui lui est associé indépendamment du niveau de journalisation. L'Appender ignore tous les messages de journalisation dont le niveau est inférieur au niveau de seuil.
filtre Les objets Filter peuvent analyser les informations de journalisation au-delà de la correspondance de niveau et décider si les demandes de journalisation doivent être gérées par un Appender particulier ou ignorées.

Nous pouvons ajouter un objet Appender à un enregistreur en incluant le paramètre suivant dans le fichier de configuration avec la méthode suivante:

log4j.logger.[logger-name]=level, appender1,appender..n

Vous pouvez écrire la même configuration au format XML comme suit:

<logger name="com.apress.logging.log4j" additivity="false">
   <appender-ref ref="appender1"/>
   <appender-ref ref="appender2"/>
</logger>

Si vous souhaitez ajouter un objet Appender dans votre programme, vous pouvez utiliser la méthode suivante:

public void addAppender(Appender appender);

La méthode addAppender () ajoute un Appender à l'objet Logger. Comme le montre l'exemple de configuration, il est possible d'ajouter de nombreux objets Appender à un enregistreur dans une liste séparée par des virgules, chaque impression des informations de journalisation vers des destinations distinctes.

Nous n'avons utilisé qu'un seul appender FileAppender dans notre exemple ci-dessus. Toutes les options d'ajout possibles sont:

  • AppenderSkeleton
  • AsyncAppender
  • ConsoleAppender
  • DailyRollingFileAppender
  • ExternallyRolledFileAppender
  • FileAppender
  • JDBCAppender
  • JMSAppender
  • LF5Appender
  • NTEventLogAppender
  • NullAppender
  • RollingFileAppender
  • SMTPAppender
  • SocketAppender
  • SocketHubAppender
  • SyslogAppender
  • TelnetAppender
  • WriterAppender

Nous couvririons FileAppender dans Logging in Files et JDBC Appender serait couvert dans Logging in Database .

Disposition

Nous avons utilisé PatternLayout avec notre appender. Toutes les options possibles sont:

  • DateLayout
  • HTMLLayout
  • PatternLayout
  • SimpleLayout
  • XMLLayout

En utilisant HTMLLayout et XMLLayout, vous pouvez également générer un journal au format HTML et XML.

Formatage de la mise en page

Vous apprendrez comment formater un message de journal dans le chapitre: Formatage de journal .

Nous avons vu comment créer un fichier de configuration. Ce chapitre décrit comment générer des messages de débogage et les consigner dans un simple fichier texte.

Voici un simple fichier de configuration créé pour notre exemple. Révisons-le encore une fois:

  • Le niveau de l'enregistreur racine est défini comme DEBUG et y attache un appender nommé FILE.

  • L'appender FILE est défini comme org.apache.log4j.FileAppender et écrit dans un fichier nommé "log.out" situé dans le log annuaire.

  • Le modèle de disposition défini est% m% n, ce qui signifie que le message de journalisation imprimé sera suivi d'un caractère de nouvelle ligne.

Le contenu du fichier log4j.properties est le suivant:

# Define the root logger with appender file
log = /usr/home/log4j
log4j.rootLogger = DEBUG, 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

Utilisation de log4j dans le programme Java

La classe Java suivante est un exemple très simple qui initialise, puis utilise, la bibliothèque de journalisation Log4J pour les applications Java.

import org.apache.log4j.Logger;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class log4jExample{
   /* Get actual class name to be printed on */
   static Logger log = Logger.getLogger(log4jExample.class.getName());
   
   public static void main(String[] args)throws IOException,SQLException{
      log.debug("Hello this is a debug message");
      log.info("Hello this is an info message");
   }
}

Compiler et exécuter

Voici les étapes pour compiler et exécuter le programme mentionné ci-dessus. Assurez-vous que vous avez définiPATH et CLASSPATH de manière appropriée avant de procéder à la compilation et à l'exécution.

Toutes les bibliothèques doivent être disponibles en CLASSPATHet votre fichier log4j.properties doit être disponible dans PATH. Suivez les étapes ci-dessous:

  • Créez log4j.properties comme indiqué ci-dessus.

  • Créez log4jExample.java comme indiqué ci-dessus et compilez-le.

  • Exécutez le binaire log4jExample pour exécuter le programme.

Vous obtiendrez le résultat suivant dans le fichier /usr/home/log4j/log.out:

Hello this is a debug message
Hello this is an info message

La classe Logger fournit une variété de méthodes pour gérer les activités de journalisation. La classe Logger ne nous permet pas d'instancier une nouvelle instance Logger mais elle fournit deux méthodes statiques pour obtenir un objet Logger:

  • public static Logger getRootLogger();
  • public static Logger getLogger(String name);

La première des deux méthodes renvoie le journal racine de l'instance d'application et elle n'a pas de nom.

Toute autre instance d'objet Logger nommée est obtenue via la deuxième méthode en transmettant le nom de l'enregistreur. Le nom de l'enregistreur peut être n'importe quelle chaîne que vous pouvez passer, généralement une classe ou un nom de package comme nous l'avons utilisé dans le dernier chapitre et il est mentionné ci-dessous:

static Logger log = Logger.getLogger(log4jExample.class.getName());

Méthodes de journalisation

Une fois que nous avons obtenu une instance d'un enregistreur nommé, nous pouvons utiliser plusieurs méthodes de l'enregistreur pour consigner les messages. La classe Logger dispose des méthodes suivantes pour imprimer les informations de journalisation.

Sr. Non Méthodes et description
1 public void debug(Object message)

Il imprime les messages avec le niveau Level.DEBUG.

2 public void error(Object message)

Il imprime les messages avec le niveau Level.ERROR.

3 public void fatal(Object message);

Il imprime les messages avec le niveau Level.FATAL.

4 public void info(Object message);

Il imprime les messages avec le niveau Level.INFO.

5 public void warn(Object message);

Il imprime les messages avec le niveau Level.WARN.

6 public void trace(Object message);

Il imprime les messages avec le niveau Level.TRACE.

Tous les niveaux sont définis dans la classe org.apache.log4j.Level et toutes les méthodes mentionnées ci-dessus peuvent être appelées comme suit:

import org.apache.log4j.Logger;

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!");
   }
}

Lorsque vous compilez et exécutez le programme LogClass, il génère le résultat suivant:

Debug Message!
Info Message!
Warn Message!
Error Message!
Fatal Message!

Tous les messages de débogage ont plus de sens lorsqu'ils sont utilisés en combinaison avec des niveaux. Nous aborderons les niveaux dans le chapitre suivant, puis vous aurez une bonne compréhension de la façon d'utiliser ces méthodes en combinaison avec différents niveaux de débogage.

La classe org.apache.log4j.Level fournit les niveaux suivants. Vous pouvez également définir vos niveaux personnalisés en sous-classant la classe Level.

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 qest activé si 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 programme LogClass, il génère 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 la méthode log.setLevel (Level.WARN) 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 le fichier /usr/home/log4j/log.out:

Warn Message!
Error Message!
Fatal Message!

Apache log4j fournit divers objets de mise en page, chacun d'entre eux pouvant formater les données de journalisation selon diverses dispositions. Il est également possible de créer un objet de mise en page qui formate les données de journalisation d'une manière spécifique à l'application.

Tous les objets Layout reçoivent un objet LoggingEvent des objets Appender. Les objets Layout récupèrent ensuite l'argument du message à partir de LoggingEvent et appliquent l'ObjectRenderer approprié pour obtenir la représentation String du message.

Les types de disposition

La classe de niveau supérieur de la hiérarchie est la classe abstraite org.apache.log4j.Layout. Il s'agit de la classe de base pour toutes les autres classes Layout de l'API log4j.

La classe Layout est définie comme abstraite dans une application, nous n'utilisons jamais cette classe directement; à la place, nous travaillons avec ses sous-classes qui sont les suivantes:

  • DateLayout

  • HTMLLayout

  • PatternLayout.

  • SimpleLayout

  • XMLLayout

Les méthodes de mise en page

Cette classe fournit une implémentation squelette de toutes les opérations courantes sur tous les autres objets Layout et déclare deux méthodes abstraites.

N ° Sr. Méthodes et description
1 public abstract boolean ignoresThrowable()

Il indique si les informations de journalisation gèrent tout objet java.lang.Throwable qui lui est transmis dans le cadre de l'événement de journalisation. Si l'objet Layout gère l'objet Throwable, l'objet Layout ne l'ignore pas et renvoie false.

2 public abstract String format(LoggingEvent event)

Les sous-classes de mise en page individuelles implémentent cette méthode pour le formatage spécifique à la mise en page.

Outre ces méthodes abstraites, la classe Layout fournit une implémentation concrète des méthodes répertoriées ci-dessous:

N ° Sr. Méthodes et description
1 public String getContentType()

Il renvoie le type de contenu utilisé par les objets Layout. La classe de base renvoie text / plain comme type de contenu par défaut.

2 public String getFooter()

Il spécifie les informations de pied de page du message de journalisation.

3 public String getHeader()

Il spécifie les informations d'en-tête du message de journalisation.

Chaque sous-classe peut renvoyer des informations spécifiques à la classe en remplaçant l'implémentation concrète de ces méthodes.

Pour écrire vos informations de journalisation dans un fichier, vous devez utiliser org.apache.log4j.FileAppender .

Configuration de FileAppender

FileAppender a les paramètres configurables suivants:

Propriété La description
immédiatFlush Cet indicateur est défini par défaut sur true, ce qui signifie que le flux de sortie vers le fichier est vidé à chaque opération d'ajout.
codage Il est possible d'utiliser n'importe quel encodage de caractères. Par défaut, il s'agit du schéma de codage spécifique à la plate-forme.
seuil Le niveau de seuil pour cet ajouteur.
Nom de fichier Le nom du fichier journal.
fichierAppend Cette valeur est définie par défaut sur true, ce qui signifie que les informations de journalisation sont ajoutées à la fin du même fichier.
bufferedIO Cet indicateur indique si nous avons besoin d'activer l'écriture en mémoire tampon. Par défaut, il est défini sur false.
bufferSize Si les E / S tamponnées sont activées, cela indique la taille de la mémoire tampon. Par défaut, il est défini sur 8 Ko.

Voici un exemple de fichier de configuration log4j.properties pour FileAppender.

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, overwrite
log4j.appender.FILE.Append=false

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

Si vous souhaitez avoir un fichier de configuration XML équivalent au fichier log4j.properties ci-dessus , voici le contenu:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration>

<appender name="FILE" class="org.apache.log4j.FileAppender">
   <param name="file" value="${log}/log.out"/>
   <param name="immediateFlush" value="true"/>
   <param name="threshold" value="debug"/>
   <param name="append" value="false"/>
   <layout class="org.apache.log4j.PatternLayout">
      <param name="conversionPattern" value="%m%n"/>
   </layout>
</appender>

<logger name="log4j.rootLogger" additivity="false">
   <level value="DEBUG"/>
   <appender-ref ref="FILE"/>
</logger>

</log4j:configuration>

Vous pouvez essayer log4j - Exemple de programme avec la configuration ci-dessus.

Connexion à plusieurs fichiers

Vous souhaiterez peut-être écrire vos messages de journal dans plusieurs fichiers pour certaines raisons, par exemple, si la taille du fichier atteint un certain seuil.

Pour écrire vos informations de journalisation dans plusieurs fichiers, vous devez utiliser la classe org.apache.log4j.RollingFileAppender qui étend la classe FileAppender et hérite de toutes ses propriétés.

Nous avons les paramètres configurables suivants en plus de ceux mentionnés ci-dessus pour FileAppender:

Propriété La description
maxFileSize Il s'agit de la taille critique du fichier au-dessus de laquelle le fichier sera roulé. La valeur par défaut est de 10 Mo.
maxBackupIndex Cette propriété indique le nombre de fichiers de sauvegarde à créer. La valeur par défaut est 1.

Voici un exemple de fichier de configuration log4j.properties pour RollingFileAppender.

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.RollingFileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, should not overwrite
log4j.appender.FILE.Append=true

# Set the maximum file size before rollover
log4j.appender.FILE.MaxFileSize=5MB

# Set the the backup index
log4j.appender.FILE.MaxBackupIndex=2

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

Si vous souhaitez avoir un fichier de configuration XML, vous pouvez générer le même que celui mentionné dans la section initiale et ajouter uniquement des paramètres supplémentaires liés à RollingFileAppender .

Cet exemple de configuration montre que la taille maximale autorisée de chaque fichier journal est de 5 Mo. En cas de dépassement de la taille maximale, un nouveau fichier journal sera créé. Étant donné que maxBackupIndex est défini comme 2, une fois que le deuxième fichier journal atteint la taille maximale, le premier fichier journal sera effacé et ensuite, toutes les informations de journalisation seront restaurées dans le premier fichier journal.

Vous pouvez essayer log4j - Exemple de programme avec la configuration ci-dessus.

Génération de fichiers journaux quotidiens

Il peut être nécessaire de générer vos fichiers journaux quotidiennement pour conserver un enregistrement propre de vos informations de journalisation.

Pour écrire quotidiennement vos informations de journalisation dans des fichiers, vous devez utiliser la classe org.apache.log4j.DailyRollingFileAppender qui étend la classe FileAppender et hérite de toutes ses propriétés.

Il n'y a qu'un seul paramètre configurable important en plus de ceux mentionnés ci-dessus pour FileAppender:

Propriété La description
DatePattern Cela indique quand survoler le fichier et la convention de dénomination à suivre. Par défaut, le roll over est effectué à minuit chaque jour.

DatePattern contrôle le planning de substitution à l'aide de l'un des modèles suivants:

DatePattern La description
'.' aaaa-MM Reportez-vous à la fin de chaque mois et au début du mois suivant.
'.' aaaa-MM-jj Roulez chaque jour à minuit. Ceci est la valeur par défault.
'.' aaaa-MM-jj-a Survolez à midi et à minuit de chaque jour.
'.' aaaa-MM-jj-HH Retournez au début de chaque heure.
'.' aaaa-MM-jj-HH-mm Roulez chaque minute.
'.' aaaa-ww Survolez le premier jour de chaque semaine en fonction de la localisation.

Voici un exemple de fichier de configuration log4j.properties pour générer des fichiers journaux reportés chaque jour à midi et à minuit.

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.DailyRollingFileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, should not overwrite
log4j.appender.FILE.Append=true

# Set the DatePattern
log4j.appender.FILE.DatePattern='.' yyyy-MM-dd-a

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

Si vous souhaitez avoir un fichier de configuration XML, vous pouvez générer le même que celui mentionné dans la section initiale et ajouter uniquement des paramètres supplémentaires liés à DailyRollingFileAppender .

Vous pouvez essayer log4j - Exemple de programme avec la configuration ci-dessus.

L'API log4j fournit l' objet org.apache.log4j.jdbc.JDBCAppender , qui peut placer les informations de journalisation dans une base de données spécifiée.

Configuration de JDBCAppender

Propriété La description
bufferSize Définit la taille du tampon. La taille par défaut est 1.
chauffeur Définit la classe de pilote sur la chaîne spécifiée. Si aucune classe de pilote n'est spécifiée, la valeur par défaut est sun.jdbc.odbc.JdbcOdbcDriver.
disposition Définit la mise en page à utiliser. La disposition par défaut est org.apache.log4j.PatternLayout.
mot de passe Définit le mot de passe de la base de données.
sql Spécifie l'instruction SQL à exécuter chaque fois qu'un événement de journalisation se produit. Cela peut être INSERT, UPDATE ou DELETE.
URL Définit l'URL JDBC.
utilisateur Définit le nom d'utilisateur de la base de données.

Configuration de la table des journaux

Avant de commencer à utiliser la journalisation basée sur JDBC, vous devez créer une table pour conserver toutes les informations du journal. Voici l'instruction SQL pour créer la table LOGS:

CREATE TABLE LOGS
   (USER_ID VARCHAR(20) NOT NULL,
    DATED   DATE NOT NULL,
    LOGGER  VARCHAR(50) NOT NULL,
    LEVEL   VARCHAR(10) NOT NULL,
    MESSAGE VARCHAR(1000) NOT NULL
   );

Exemple de fichier de configuration

Voici un exemple de fichier de configuration log4j.properties pour JDBCAppender qui sera utilisé pour consigner les messages dans une table LOGS.

# Define the root logger with appender file
log4j.rootLogger = DEBUG, DB

# Define the DB appender
log4j.appender.DB=org.apache.log4j.jdbc.JDBCAppender

# Set JDBC URL
log4j.appender.DB.URL=jdbc:mysql://localhost/DBNAME

# Set Database Driver
log4j.appender.DB.driver=com.mysql.jdbc.Driver

# Set database user name and password
log4j.appender.DB.user=user_name
log4j.appender.DB.password=password

# Set the SQL statement to be executed.
log4j.appender.DB.sql=INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')

# Define the layout for file appender
log4j.appender.DB.layout=org.apache.log4j.PatternLayout

Pour la base de données MySQL, vous devrez utiliser le DBNAME réel, l'ID utilisateur et le mot de passe, où vous avez créé la table LOGS. L'instruction SQL consiste à exécuter une instruction INSERT avec le nom de table LOGS et les valeurs à saisir dans la table.

JDBCAppender n'a pas besoin d'une mise en page pour être définie explicitement. Au lieu de cela, l'instruction SQL qui lui est transmise utilise un PatternLayout.

Si vous souhaitez avoir un fichier de configuration XML équivalent au fichier log4j.properties ci-dessus , voici le contenu:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration>

<appender name="DB" class="org.apache.log4j.jdbc.JDBCAppender">
   <param name="url" value="jdbc:mysql://localhost/DBNAME"/>
   <param name="driver" value="com.mysql.jdbc.Driver"/>
   <param name="user" value="user_id"/>
   <param name="password" value="password"/>
   <param name="sql" value="INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')"/>
   <layout class="org.apache.log4j.PatternLayout">
   </layout>
</appender>

<logger name="log4j.rootLogger" additivity="false">
   <level value="DEBUG"/>
   <appender-ref ref="DB"/>
</logger>

</log4j:configuration>

Exemple de programme

La classe Java suivante est un exemple très simple qui initialise puis utilise la bibliothèque de journalisation Log4J pour les applications Java.

import org.apache.log4j.Logger;
import java.sql.*;
import java.io.*;
import java.util.*;

public class log4jExample{
   /* Get actual class name to be printed on */
   static Logger log = Logger.getLogger(log4jExample.class.getName());
   
   public static void main(String[] args)throws IOException,SQLException{
      log.debug("Debug");
      log.info("Info");
   }
}

Compiler et exécuter

Voici les étapes pour compiler et exécuter le programme mentionné ci-dessus. Assurez-vous que vous avez définiPATH et CLASSPATH de manière appropriée avant de procéder à la compilation et à l'exécution.

Toutes les bibliothèques doivent être disponibles en CLASSPATHet votre fichier log4j.properties doit être disponible dans PATH. Suivez les étapes indiquées:

  • Créez log4j.properties comme indiqué ci-dessus.
  • Créez log4jExample.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire log4jExample pour exécuter le programme.

Vérifiez maintenant votre table LOGS dans la base de données DBNAME et vous trouverez les entrées suivantes:

mysql >  select * from LOGS;
+---------+------------+--------------+-------+---------+
| USER_ID | DATED      | LOGGER       | LEVEL | MESSAGE |
+---------+------------+--------------+-------+---------+
|         | 2010-05-13 | log4jExample | DEBUG | Debug   |
|         | 2010-05-13 | log4jExample | INFO  | Info    |
+---------+------------+--------------+-------+---------+
2 rows in set (0.00 sec)

Note:Ici, x est utilisé pour générer le contexte de diagnostic imbriqué (NDC) associé au thread qui a généré l'événement de journalisation. Nous utilisons NDC pour distinguer les clients dans les composants côté serveur gérant plusieurs clients. Consultez le manuel Log4J pour plus d'informations à ce sujet.