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 :

[Perf]Utilisation des Logger et temps de traitement ?


Sujet :

Logging Java

  1. #1
    Expert éminent
    Avatar de elitost
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2003
    Messages
    1 985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 985
    Points : 6 566
    Points
    6 566
    Par défaut [Perf]Utilisation des Logger et temps de traitement ?
    Bonjour,

    Est ce que l'utilisation de loggers ralentit une appli web java , en fait , est ce que les retirer permet de gagner du temps ?

    Merci d'avance



    [Modéré par Didier] : ajout de tag dans le titre - Les règles du forum Java

  2. #2
    Membre averti
    Inscrit en
    Mars 2004
    Messages
    377
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 377
    Points : 356
    Points
    356
    Par défaut
    Normalement pas grand chose puisque l'écriture sur le fichier ne se fait pas si tu as un niveau de log bas (INFO) (les tests sont effectuées au début de la méthode si les classes sont bien faites.), oui si tu es en DEBUG.
    Enfin plus de temps. Clairement.

  3. #3
    Membre éprouvé

    Profil pro
    Inscrit en
    Mars 2002
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2002
    Messages : 652
    Points : 1 151
    Points
    1 151
    Par défaut
    Ce qui coute n'est pas le fait de logger à proprement parler mais d'évaluer ce que tu vas logger.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Log.debug("toto"); //ne coute rien du tout !
    par contre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Log.debug("Error occured " + e.getMessage() + ", " + e.getCode());
    // coute l'évaluation de '"Error occured " + e.getMessage() + ", " + e.getCode()'
    C'est pour celà que l'api de log java met à disposition la méthode
    public boolean isLoggable(Level level)
    Log4J met la méthode :
    public boolean isDebugEnabled()
    Ainsi ton code un peu plus optimisé donne ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    if( logger.isDebugEnabled()) {
      logger.debug("Error occured " + e.getMessage() + ", " + e.getCode());
    }

  4. #4
    ndp
    ndp est déconnecté
    Membre actif Avatar de ndp
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 227
    Points : 255
    Points
    255
    Par défaut
    Ainsi ton code un peu plus optimisé donne ceci
    C'est juste pour aller dans le meme sens, il ne faut pas se priver de cette optimisation! Imagine une grosse application J2EE avec des appels distants, et des logs dans toutes les methodes. Si tu ne faits pas le test, tu instancies un nombre tres importants de String buffer et les performances s'ecroulent.

  5. #5
    Expert éminent
    Avatar de elitost
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2003
    Messages
    1 985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 985
    Points : 6 566
    Points
    6 566
    Par défaut
    Existe t'il des sites web qui bench les performances de l'utilisation de tel ou tel objet en JAVA ?

    Ceci afin de savoir ce qu'il vaut mieux eviter d'utiliser ?

  6. #6
    Membre averti
    Inscrit en
    Mars 2004
    Messages
    377
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 377
    Points : 356
    Points
    356
    Par défaut
    Un site sur la performance en JAVA.
    Très bien pour éviter les erreurs grossières.

    http://www.javaperformancetuning.com/

  7. #7
    Expert éminent
    Avatar de elitost
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2003
    Messages
    1 985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 985
    Points : 6 566
    Points
    6 566
    Par défaut
    ok, merci

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

Discussions similaires

  1. Débutant : utilisation des matrices en traitement d'image
    Par Black Templar dans le forum Traitement d'images
    Réponses: 4
    Dernier message: 17/11/2008, 08h37
  2. utilisation des request VS traitement dans jsp
    Par aurelien(toupil) dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 17/08/2007, 14h59
  3. temps de traitement des curseurs
    Par charluber dans le forum Oracle
    Réponses: 1
    Dernier message: 20/04/2006, 10h46
  4. Réponses: 7
    Dernier message: 27/01/2006, 01h44
  5. Utilisation JProgressBar & temps de traitement incconu
    Par greg1602 dans le forum Composants
    Réponses: 22
    Dernier message: 30/11/2005, 20h52

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