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

Java EE Discussion :

Erreur connexion à la DB


Sujet :

Java EE

  1. #1
    Invité
    Invité(e)
    Par défaut Erreur connexion à la DB
    Bonjour,

    voila j'ai crée une application j2ee qui tourne sous tomcat et utilise mysql.

    le problème c'est que si je laisse le serveur tourné toute la nuit le matin je trouve une erreur d’accès a la base de donnée quand j'ouvre mon application.

    pour ce connecté j'utilise ceci :

    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
     
    package utilitaire;
     
    import java.sql.*;
     
    public class DB {
    	//Code pour ce connecetr a la base MySQL
    	static Connection Conn;
    	Statement st;
    	private String hoste = "jdbc:mysql://localhost/mabase";
    	private String login = "root";
    	private String pass = "";
    	private String err;
    	public String getErr() {
    		return err;
    	}
    	public DB(){
    		if(Conn == null){
    		this.Conn();
    		} else {
    			System.out.println("CONNEXION SQL EXISTANTE ! ");
    		}
    	}
     
     
    	private Connection Conn(){
    		try
    		{
    			Class.forName("com.mysql.jdbc.Driver");	
    			Conn=DriverManager.getConnection(hoste,login,pass);
    			System.out.println("Connected");
     
    		}
    		catch (Exception e) 
    		{
    			System.out.println("No Connction :"+Conn);
    			System.out.println(e.getMessage());
    			this.err = e.getMessage();
    			Log log = new Log();
    			log.SLog("----------Fichier : DB.java-------------\n");
    			log.SLog(e.getMessage()+"\n");
    			log.SLog("-----------------------------------------\n");
    		}
     
    		return Conn;
    	}
     
    	public ResultSet Query(String rq) throws SQLException{
    		st = Conn.createStatement();
    		return st.executeQuery(rq);
    	}
    	public int Update(String rq) throws SQLException {
    		// TODO Auto-generated method stub
    		st = Conn.createStatement();
    		PreparedStatement prepare = Conn.prepareStatement(rq);
    		int R = prepare.executeUpdate();
    		prepare.close();
    		return R;
    	}
    }
    donc a chaque fouis que je veux utiliser ma connexion soit dans une jsp ou une servelet ou simplement une classe java je creé une nouvelle classe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    DB con = new DB();
    con.query() etc...
    mais je me déconnecte pas.

    Que penser vous ?

    Merci.

  2. #2
    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
    Citation Envoyé par newbe-deve Voir le message
    le matin je trouve une erreur d’accès a la base de donnée quand j'ouvre mon application.
    Quelle erreur?

    pour ce connecté j'utilise ceci :
    C'est erroné. Ta connexion étant statique, plusieurs pages JSP demandées en même temps peuvent utiliser le même objet Connection simultanément, et cet objet n'est pas Thread-Safe.

    Le mieux serait de te reposer sur les connexion pool que t'offre tomcat. Comme ça plus besoin de gérer la connexion dans ton code. Tu prend une connexion dans le pool et tu la rend à la fin de la page.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Pour l'erreur j'avais fais a try catch avec un message personnel du coup j'ai pas pu avoir le message d'erreur de la console (tien dans le log je met le message de la console ça serai bien pour la gestion d'erreur), par contre ton idée de pool ça ma l'aire bien je la connaissez pas mais je me demande si mon application est utilisé par plusieurs personne et 2 entre eux par exemple essai de modifier une ligne x dans une table y si tu voie ce que je veux dire ça va foutre le bordel nn ?
    est-ce que c'est possible de gérer ce genre de conflit ou le pool de tomcat le gère automatiquement peux êtres.

    Merci.

  4. #4
    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
    C'est le rôle de la base de données et des transaction de gérer ces conflits.

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bon voila j'ai essayer de faire le truc de pool de tomcat j'ai fais tous ce qui est dit sur Devloppez mais j'ai pas réussit du coup j'ai trouver un petit exemple sur le site de tomcat hop copier coller et il me met une erreur sur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    import org.apache.tomcat.jdbc.pool.DataSource;
    import org.apache.tomcat.jdbc.pool.PoolProperties;
    il sont pas sur tomcat normalement ?

    si non si ta un autre tuto sur comment faire ça serai sympa

    Merci.

  6. #6
    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
    ton application ne verra pas les classes de tomcat, elles sont dans une classloader séparé. Suit les instruction du tutoriel sur dvp, elles m'ont l'air tout à fait correctes et standards.

  7. #7
    Invité
    Invité(e)
    Par défaut
    d’acore , est-ce possible de te poster ici si je trouve un soucis ?

    Merci

  8. #8
    Invité
    Invité(e)
    Par défaut
    re Bonjour,

    voila j'ai fais ce qui est dit dans le tuto de pool tomcat mais j'ai cette erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Etat HTTP 500 - Exception sur l'accès à la BDD org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null'
     
    type Rapport d''état
     
    message Exception sur l'accès à la BDD org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null'
     
    description Le serveur a rencontré une erreur interne (Exception sur l'accès à la BDD org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null') qui l'a empêché de satisfaire la requête.
    Apache Tomcat/7.0.27
    je comprend pas c'est quoi le problème

    Merci

  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
    Visiblement tu as oublié des paramètre dans ta configuration, en l'occurence, l'url de connexion.

  10. #10
    Invité
    Invité(e)
    Par défaut
    Merci c bon j'ai trouver un autre tuto et ça a marché Merci et donc si j'utilise ce type de connexion j'aurai pas de problème dans mon application ?

  11. #11
    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
    Tu en aura moins, déjà. Après pour les autres problèmes, ben faudra voir quand ils arriveront

  12. #12
    Invité
    Invité(e)
    Par défaut
    Ce que j'ai fait c'est que j'ai créé un projet test pour faire la connexion pool de tomcat, mais pas directement dans l'application par contre j'ai ajouté l'option autoReconnect=true dans mon ancienne connexion et ça a l'air de marcher, mais j'aimerais comprendre pourquoi le singleton que j'ai fait (la connexion static) va me poser problème pourquoi il faut le threder ? j'aimerais bien que vous m'expliquiez s.v.p.

    Merci

  13. #13
    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 vosu l'ai dit, quand vous aurez deux page en même temps qui vont utiliser la même connexion, vous allez avoir des problèmes car les connexion jdbc ne sont pas multi thread.

  14. #14
    Invité
    Invité(e)
    Par défaut
    Merci

  15. #15
    Invité
    Invité(e)
    Par défaut
    j'ai un petit soucis ,

    comment utiliser la connexion de pool dans une classe normale java ?

  16. #16
    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
    Tu récupère la datasource via la JNDI, tout simplement
    Exemple de la doc tomcat

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    InitialContext cxt = new InitialContext();
    if ( cxt == null ) {
       throw new Exception("Uh oh -- no context!");
    }
     
    DataSource ds = (DataSource) cxt.lookup( "java:/comp/env/jdbc/taconnexion" );
     
    if ( ds == null ) {
       throw new Exception("Data source not found!");
    }

  17. #17
    Invité
    Invité(e)
    Par défaut
    voici linit de ma servelet :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
        public void init() throws ServletException {
            try {
                // Get DataSource
                Context initContext  = new InitialContext();
                Context envContext  = (Context)initContext.lookup("java:/comp/env");
                dataSource = (DataSource)envContext.lookup("jdbc/testdb");
     
            } catch (NamingException e) {
                e.printStackTrace();
            }
        }
    et voici le teste dans une classe normale:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    public static void main(String[] args) throws Exception {
    		// TODO Auto-generated method stub
    		InitialContext cxt = new InitialContext();
    		DataSource ds = (DataSource) cxt.lookup( "java:/comp/env/jdbc/testdb" );
     
    		if ( ds == null ) {
    		   throw new Exception("Data source not found!");
    		}
    	}
    mais je comprend pas l'erreur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Exception in thread "main" javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file:  java.naming.factory.initial
    	at javax.naming.spi.NamingManager.getInitialContext(Unknown Source)
    	at javax.naming.InitialContext.getDefaultInitCtx(Unknown Source)
    	at javax.naming.InitialContext.getURLOrDefaultInitCtx(Unknown Source)
    	at javax.naming.InitialContext.lookup(Unknown Source)
    	at tutoriel.test.main(test.java:22)
    Need to specify class name : il est spécifier enfin j'ai pas changé la configuration et ça marche avec la servelet
    Dernière modification par Invité ; 25/04/2012 à 15h58.

  18. #18
    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
    on n'utilise pas de main dans un conteneur J2EE, on déploie sur le serveur J2EE!

  19. #19
    Invité
    Invité(e)
    Par défaut
    Ah oui vous avez raison ça ma échappée

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 04/04/2006, 21h36
  2. [BO5.1.3][oracle9] Erreur connexion DA0005:1010
    Par ggnore dans le forum Oracle
    Réponses: 12
    Dernier message: 04/10/2005, 15h00
  3. Erreur connexion MySQL-PHP
    Par specialfox dans le forum Installation
    Réponses: 3
    Dernier message: 27/09/2005, 20h47
  4. [CE10 Pro] Erreur Connexion SQL pour etats publiés
    Par L.nico dans le forum Connectivité
    Réponses: 1
    Dernier message: 09/12/2004, 18h16
  5. Erreur connexion mysql
    Par bodbod dans le forum Bases de données
    Réponses: 3
    Dernier message: 10/07/2004, 10h28

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