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

Langage Java Discussion :

Java heap space


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    199
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 199
    Par défaut Java heap space
    Bonjour,
    Je développe une application web et j'ai une page qui s'affiche une fois puis plus du tout. J'utilise le profiler de Netbeans qui semble indiquer que toute la mémoire (heap) est utilisée lorsque je vais chercher les éléments à afficher dans la base de données puisqu'il renvoit une erreur de type "heap crash" : je créé en effet une liste (ArrayList) à partir des éléments récupérés dans une base de données. Ce qui m'étonne, c'est que la requête ne va chercher "qu"'environ 8000 instances d'objets contenant une quarantaine de champs. Est-ce trop ?
    Le profiler semble également indiquer que la mémoire est "limitée" à 64 Mo. S'il s'avère que ce n'est pas un problème de code, comment peut-on augmenter cette valeur ?
    Merci par avance pour votre aide.

  2. #2
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    si je prend un taille moyenne de 16 octets par objet récupéré, ca nous amène à 5M utilisé juste pour une requete. Si t'as des string, la taille riisque d'etre plus élevée. Augmenter la mémoire disponible n'est qu'un rustine (paramètre -Xmx de la jvm) au problème de base, la requete est gourmande et va très mal supporter l'agrandissement de l'application (5 demande simultanée de la liste, 5 fois plus de mémoire nécessaire). Il serait plus judicieux peut etre de générer ta réponse au fur et à mesure que tu lit de la db, plutot que de tout stocker en mémoire pour ensuite faire la réponse.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    199
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 199
    Par défaut
    Ok, je voulais savoir si ce comportement était "normal". Je vais modifier mon code pour gérer moins d'objets à la fois.
    Merci pour ta réponse. S'il y a d'autres suggestions, je suis preneuse.

  4. #4
    Membre chevronné
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    280
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 280
    Par défaut
    Salut,

    Voici ce que j'utilise comme parametres pour des serveurs tomcat:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    -Xms1024M -Xmx1024M -XX:MaxPermSize=256m
    Mais bon, je ne charge pas 8000 lignes de la DB.
    Quand je dois acceder a des grosses quantites de lignes je pagine systematiquement pour n'avoir a lire qu'un nombre plus restreint.

    As tu besoin de recuperer autant de lignes en une seule fois ?

    ---
    Farid

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    199
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 199
    Par défaut
    Le layout que j'utilise ne permet pas de ne charger que ce qu'on affiche en pagination. J'ai 8000 éléments à afficher et même si je n'en affiche que 10 par pages, je dois tous les charger... Mais je vais changer ça : plutôt que de charger ces 8000 éléments par défaut, je vais charger une liste vide et attendre que l'utilisateur fasse une recherche par critères pour n'en afficher que le résultat.
    Merci pour vos réponses.

  6. #6
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    le problème n'est pas que u charge 8000 éléments, c'est que tu charge tout en mémoire plutot que d'écrire dans le flux de sortie au fur et à mesure que tu lit de la db

Discussions similaires

  1. [Info] Chargement image et Java heap space
    Par dazz_x dans le forum Langage
    Réponses: 9
    Dernier message: 11/09/2007, 11h51
  2. Java heap space
    Par youdev dans le forum Tomcat et TomEE
    Réponses: 3
    Dernier message: 10/07/2007, 11h10
  3. [jarsigner] java heap space
    Par GLDavid dans le forum Langage
    Réponses: 3
    Dernier message: 16/08/2006, 11h35
  4. Eclipse erreur : java.lang.OutOfMemoryError: Java heap space
    Par sderecourt dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 14/04/2006, 11h28
  5. [ memoire ] Java Heap Space
    Par natha dans le forum Général Java
    Réponses: 10
    Dernier message: 23/01/2006, 11h15

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