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

Hibernate Java Discussion :

Problème mémoire application multi-utilisateur


Sujet :

Hibernate Java

  1. #1
    Membre du Club
    Inscrit en
    Août 2008
    Messages
    85
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 85
    Points : 46
    Points
    46
    Par défaut Problème mémoire application multi-utilisateur
    Bonjour,

    Dans un environnement Eclipse / Tomcat / Hibernate / Postgres, j'ai une application de type web, multi-utilisateurs.

    Au lancement de l'application, la Session Hibernate est créée.
    J'ai des problèmes de heap space après quelques connexions et utilisations avec accès à la base de données en lecture et/ou écriture.

    Les paramètres Xms et Xmx sont ok.

    Donc, comment puis-je faire un session.flush() et session.clear(), sachant qu'il existe une session Hibernate utile à plusieurs utilisateurs ?

    En gros en fin de traitement si je fais un flush et un clear il est possible du coup, je l'ai testé, de déconnecter un autre utilisateur de cette même méthode qu'il était en train d'utiliser pour faire un accès BDD.

    Merci d'avance pour votre aide.

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 274
    Points : 4 141
    Points
    4 141
    Par défaut
    La session Hibernate n'est pas censée etre partagée par plusieurs utilisateurs simultanément.

  3. #3
    Membre du Club
    Inscrit en
    Août 2008
    Messages
    85
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 85
    Points : 46
    Points
    46
    Par défaut
    J'ai une application qui est accédée par des utilisateurs qui peuvent requêter sur une base de données.
    L'accès à cette dernière, lecture/écriture est faite à travers Hibernate.

    Peux-tu expliquer un peu plus ton point de vue sur le : c'est pas fait pour ça

    merci

  4. #4
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 274
    Points : 4 141
    Points
    4 141
    Par défaut
    Disons, que la session Hibernate est censée avoir une durée de vie courte.
    Généralement, pour chaque requete utilisateur, tu crées une session, tu fais ton travail et tu fermes la session.
    La gestion de la session peut etre gérée de manière automatique, c'est à dire associée au thread courant ou à la transaction courante.

    C'est la sessionFactory qui est partagée entre les utilisateurs et notamment, son cache de second niveau.

  5. #5
    Membre du Club
    Inscrit en
    Août 2008
    Messages
    85
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 85
    Points : 46
    Points
    46
    Par défaut
    Intéressant

    donc si dans ce code je vois un builFactory
    qu'après je ne vois que des
    HibernateUtil.getSessionFactory().getCurrentSession();

    est ce que ça veut dire que cette méthode génère une session ?

    sinon qu'est ce qui génère la session utilisateur hibernate et question accessoire, pourquoi quand je fais un session.flush() et session.clear() à partir de l'interface utilisateur d'un user A ces deux ordres entrainent le close d'une autre session utilisateur mettons du user B?

  6. #6
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 274
    Points : 4 141
    Points
    4 141
    Par défaut
    Le getCurrentSession() récupère à la session associé au thread ou à la transaction courante, ça dépend de ta config.
    Si le flush() ou clear() touche deux utilisateurs, c'est qu'ils partagent à priori, le meme objet session.

  7. #7
    Expert éminent sénior
    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 : 45
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 804
    Points
    48 804
    Par défaut
    je rajoute que les sessions hibernate ne sont pas thread safe -> ne sont pas censées être utilisé par des threads différents en même temps.

    Enfin, les objet hibernate ne doivent surtout pas être conservés dans la sessions http ou, pire, dans l'application contexte. Leur durée de vie doit être limitée à celle de la session hibernate qui ne dois pas dépasser la durée d'une requete http.

  8. #8
    En attente de confirmation mail
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Octobre 2010
    Messages
    501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2010
    Messages : 501
    Points : 1 060
    Points
    1 060
    Par défaut
    Bonjour,

    Comment savez-vous que ce sont les connexions le problème ? Avez-vous fait une analyse mémoire ?

    Théoriquement, votre problème ne devrait pas avoir lieu
    Assurez-vous que vous appelez bien les méthodes close sur les *Statement, les ResultSet et les Connexion. Et ce de manière sécurisée (dans un finally).

    Il y a néanmoins certains drivers qui sont buggés... Quel driver utilisez-vous et pour quelle type de base de données ?

  9. #9
    Expert éminent sénior
    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 : 45
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 804
    Points
    48 804
    Par défaut
    Nudger: je pense qu'il parlais juste de connexion http de ses utilisateurs :p Si on garde les session hibernate ad vitam en mémoire, inévitablement, elles finissent par être une copie en mémoire de la DB. Plus la DB est grosse, plus il y aura de données

Discussions similaires

  1. Réponses: 2
    Dernier message: 02/07/2009, 10h02
  2. Application multi-utilisateur + lock
    Par Ruddy dans le forum ASP.NET
    Réponses: 9
    Dernier message: 17/12/2007, 11h22
  3. [ASP.net & VB.net] Application multi-utilisateur
    Par miya dans le forum ASP.NET
    Réponses: 4
    Dernier message: 03/04/2007, 16h48
  4. [sql server 2000] application multi utilisateur
    Par miya dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 02/04/2007, 20h43
  5. Problème de sauvegarde multi utilisateur
    Par tribaleur dans le forum Access
    Réponses: 2
    Dernier message: 20/06/2006, 15h00

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