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

Struts 1 Java Discussion :

quand fermer la datasource


Sujet :

Struts 1 Java

  1. #1
    Membre confirmé
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Par défaut quand fermer la datasource
    'jour.

    J'ai crée une classe qui est chargée de récupérer la datasource de tomcat :

    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
     
    public class monDAO {
        private DataSource ds;
        private Connection conn;
     
        public monDAO() throws SQLException, Exception {
           InitialContext cxt = new InitialContext();
           if ( cxt == null ) {
                 throw new Exception("Pas de context!");
           }
           ds = (DataSource) cxt.lookup( "java:/comp/env/jdbc/postgres" );
           conn = ds.getConnection();
     
        }
         public ResultSet executeQuery(String query) throws SQLException {
     
            PreparedStatement prstat = null;
            ResultSet set = null;
     
            prstat = conn.prepareStatement(query);
            set = prstat.executeQuery();
     
            return set;
        }
    }
    Lorsque j'ai besoin d'envoyer une requête, je crée un objet de cette classe et appel ma méthode executeQuery.

    Mon soucis, c'est que je ne ferme jamais la connexion. Et donc forcement ya un moment où
    javax.servlet.ServletException: Cannot get a connection, pool exhausted
    Donc la question c'est : à quel moment dois-je faire mon conn.close() ?
    Après chaque requête ?

    Si j'ai bien compris il n'y a pas vraiment de destructeur en java.


    Et sinon est-il possible d'avoir mon objet tout le temps à disposition sans avoir à le réinstancier ?

    J'utilise struts.

  2. #2
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 348
    Par défaut
    L'idée du pool de connection c'est d'avoir des objets dedans, que tu prends et que tu rends au pool...
    C'est une des façons de faire, mais tu pourrais avoir d'autres choses comme un objet connection par thread, une création de connection à chaque fois et une destruction etc ...

    Pour le pool, tu dois donc fermer à chaque fois que tu as fini d'utiliser cette connection. Comme tu es en Web, cela veut donc dire avant d'envoyer la réponse au client.
    Attention, il faut fermer la connection après toutes les opérations jdbc. Ce que je veux dire, c'est que tu fermes quand tu as totalement fini de traiter ton resultset etc ...

  3. #3
    Membre confirmé
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Par défaut
    Ok, donc en gros je ferme a la fin de chaque classe qui a crée mon objet

  4. #4
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 348
    Par défaut
    Oui comme ça ça doit le faire
    N'oublie pas le tag si c'est bon

  5. #5
    Membre confirmé
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Par défaut
    Une dernière question : si je lève une exception avant le retour de ma fonction, le code situé après la ligne qui lève l'exception n'est jamais traité ?

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    123
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Avril 2007
    Messages : 123
    Par défaut
    Lorsqu'un exception en Java est levée il s'arrête en effet a la ligne ou il y a eu l'erreur et il passe au code défini dans un catch s'il y en a un, sinon il arrête le programme.

  7. #7
    Membre confirmé
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Par défaut
    ok merci

  8. #8
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 348
    Par défaut
    Citation Envoyé par Cronycs
    Lorsqu'un exception en Java est levée il s'arrête en effet a la ligne ou il y a eu l'erreur et il passe au code défini dans un catch s'il y en a un, sinon il arrête le programme.
    Euh... plus précisément il remonte à l'appelant de la méthode dans laquelle tu te trouves ...

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

Discussions similaires

  1. [FileWriter] Quand fermer le flux?
    Par michaeljeru dans le forum AWT/Swing
    Réponses: 2
    Dernier message: 08/04/2007, 00h25
  2. Réponses: 3
    Dernier message: 26/05/2006, 17h35
  3. Réponses: 4
    Dernier message: 08/05/2006, 16h41
  4. Ne pas fermer formulaire quand annulation
    Par petitours dans le forum Access
    Réponses: 2
    Dernier message: 04/05/2006, 14h48
  5. Comment fermer une fenêtre quand la souris et clavier sont inactifs ?
    Par Goldenkiller dans le forum Composants VCL
    Réponses: 7
    Dernier message: 06/12/2004, 22h09

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