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 :

Erreur NullPointerException après inactivité


Sujet :

Hibernate Java

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 22
    Par défaut Erreur NullPointerException après inactivité
    Bonjour à tous,

    Voilà j'ai un petit soucis avec la configuration de mon appli. J'utilise Tomcat 7 / Mysql / Hibernate. Quand je relance mon appli via le manager tomcat, tout marche très bien. Auparavant, après une nuit, je retournai sur ma page, et la je prenais des nullpointerexception en série, jusqu'à avoir recharger mon appli via le manager.
    J'ai depuis cibler le soucis, qui doit sans doute se trouver entre hibernate et mysql. J'ai donc raccourci les timeout de mysql afin de reproduire l'erreur plus souvent et travailler dessus.
    Cependant, après maintes et maintes reconfiguration de mon fichier hibernate.cfg.xml, je n'arrive pas à faire disparaitre ces bugs
    Je précise que cette appli fait de nombreux appel ajax synchrone vers des Servlet.
    L'erreur semble survenir quand .list() est appelé après ma l'exécution de ma requête SQL.
    Pour finir, le serveur est un serveur windows 2008 R2.

    Voici mon hibernate.cfg.xml



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
                                             "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
    <hibernate-configuration>
     <session-factory name="SessionFactory">
      <property name="hibernate.connection.url">jdbc:mysql://localhost/mydb</property>
      <property name="hibernate.connection.username">root</property>
      <property name="hibernate.connection.password">mdp</property>
      <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
     
     
     
      <!-- Connection auto reconnect after long inactivity -->
      <property name="connection.autoReconnect">true</property>
      <property name="connection.autoReconnectForPools">true</property>
      <property name="connection.is-connection-validation-required">true</property>
      <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
     
      <!--  c3p0 -->
      <!-- <property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> -->
      <property name="c3p0.min_size">5</property>
      <property name="c3p0.max_size">5</property>
      <property name="c3p0.timeout">1800</property>
      <property name="current_session_context_class">thread</property>
     
      <!-- Disable second-level cache. -->
      <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
      <property name="cache.use_query_cache">false</property>
      <property name="cache.use_minimal_puts">false</property>
      <property name="max_fetch_depth">3</property>
     
      <!-- Mappings -->
      <!--mon mapping-->
     
     </session-factory>
    </hibernate-configuration>
    Merci d'avance pour votre aide

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    394
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 394
    Par défaut
    Bonjour,

    Si tu es sur hibernate 3 tu peux ajouter un fichier c3p0.properties avec le contenu :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    c3p0.preferredTestQuery=SELECT 1
    c3p0.testConnectionOnCheckin=true
    c3p0.idleConnectionTestPeriod=300
    ça permettra à c3p0 de tester les connexions avant de te les donner, et ça évitera de te filer des connexion qui sont "mortes".

    Romain.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 22
    Par défaut
    Merci beaucoup Romain pour cette réponse !
    Je test ça de suite !

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Avril 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 22
    Par défaut
    Bon.. pas de chance les connexions continues à tomber...

    Keep digging...

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2011
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 22
    Par défaut
    Je relance un peu le débat, si débat il y a, mais lors de mes test en local je ne recontre jamais aucun problème... ils ne se produisent que lors de la mise en recette sur serveur...

  6. #6
    Membre chevronné Avatar de toutgrego
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mai 2013
    Messages
    217
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2013
    Messages : 217
    Par défaut
    Un timeout sur le serveur ?

    Je suis pas d'une grande aide, sorry

  7. #7
    Membre chevronné
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    394
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 394
    Par défaut
    C'est probablement que sur ton serveur tu as des sautes réseau.

    Tu as un pool de connexion, si une saute réseau apparait tes connexions du pool deviennent "mortes", il est nécessaire de les recréer. C'est pour ça que je t'ai fait mettre en place les "test connection", mais je ne peux pas tester ce que je t'ai proposé vu que je n'ai pas de projets du genre sous la main.

    Tu peux mettre tes properties c3p0 directement dans ta conf hibernate en fait comme indiqué ici (il y en a juste quelques unes de renommées, celles dans le tableau) : http://www.mchange.com/projects/c3p0...rnate-specific
    Ca fonctionnera peut-être mieux. Il me semble d'ailleurs que test properties sont mals nommées dans ta conf hibernate :
    You can set any c3p0 properties in your hibernate config using the prefix hibernate.c3p0. For example
    hibernate.c3p0.unreturnedConnectionTimeout=30 hibernate.c3p0.debugUnreturnedConnectionStackTraces=true
    Essaies de chercher des exemples de conf c3p0 sur le net, une conviendra peut-être à tes besoins.

    Romain.

Discussions similaires

  1. Erreur Systeme après installation de DELPHI
    Par tarbala dans le forum Delphi
    Réponses: 5
    Dernier message: 16/07/2006, 19h00
  2. Erreur 'EOleException' après un refresh
    Par Marcant dans le forum Bases de données
    Réponses: 5
    Dernier message: 01/06/2006, 18h11
  3. [VB]erreur 70 apres inscription registre
    Par bast198 dans le forum VB 6 et antérieur
    Réponses: 13
    Dernier message: 28/03/2006, 10h26
  4. [JPox] NullPointerException aprés un SELECT
    Par MinsK dans le forum Persistance des données
    Réponses: 3
    Dernier message: 05/07/2005, 13h46

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