Précédent   Forum des professionnels en informatique > Bases de données > DB2
DB2 Forum d'entraide technique sur la base de données DB2. Voir aussi -> Rubrique DB2
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 13/08/2007, 15h44   #1
Membre habitué
 
Inscription : août 2005
Messages : 152
Détails du profil
Informations personnelles :
Âge : 30
Localisation : France, Hérault (Languedoc Roussillon)

Informations forums :
Inscription : août 2005
Messages : 152
Points : 126
Points : 126
Par défaut HADR et db2jcc.jar pour programme JAVA

Bonjour,

Dans le cadre d'un développement, j'ai developpé plusieurs services/demon JAVA qui se connecte à une base de données DB2. Je travaille actuellement sur une base développeur. Pour la mise en production, une solution HADR vient d'être mise en place (1 serveur principale et un serveur alternatif en cas de panne du premier).

Je dois modifier mes programme en conséquence (etre capable d'utiliser le serveur alternatif). Cependant, je ne trouve quasiment pas d'information.

Actuellement, j'utilise pour creer ma connexion:
Code :
1
2
3
 
Class.forName("com.ibm.db2.jcc.DB2Driver");
maBase = DriverManager.getConnection(sURL, sLogin, sPassword)
.

J'ai lu quelque part qu'il fallait utiliser DataSource au lieu de DriverManager pour se connecter et profiter de HADR. Mais apres ca, je ne sais pas quoi faire. J'ai cru comprendre que la 1ere connexion au serveur devait me retourner l'adresse (ou les adresses) alternative(s), mais je ne sais pas comment les recuperer.

Pouvez-vous m'aider ?
Merci

PS: En gros, ce qu'il me faut faire:
* me connecter à la 1ere base (avec des parametres de connexion que je recupere dans un fichier ini)
* recuperer l'adresse du serveur alternatif
* executer une ou plusieurs requetes sur mon serveur 1 (ou serveur 2 en cas d'echec sur le serveur 1)

PS2: En cas d'echec de l'execution d'une requete sur le 1er serveur, dois-je moi-même me reconnecter au serveur alternatif, ou le drivers db2jcc le gerera automatiquement (en ayant connaissance de l'adresse bien sur) ?
MadCat34 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/08/2007, 16h04   #2
Membre expérimenté
 
Inscription : mai 2005
Messages : 414
Détails du profil
Informations forums :
Inscription : mai 2005
Messages : 414
Points : 589
Points : 589
Effectivement, ca ne marche pas avec DriverManager. Qui plus est DriverManager ouvre une connexion au DB2 alors qu'il est largement recommandé d'utiliser des pools de connexion surtout si tes processes sont des WebServices.

La dataSource te permettra d'utiliser les fonctionnalités HADR et la notion de pooling.

http://publib.boulder.ibm.com/infoce...c/cjvclrrt.htm

C'est la doc de DB2 v9 mais il me semble que ca fonctionne comme ca en 8 deja
gregory.broissard est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/08/2007, 16h09   #3
Membre habitué
 
Inscription : août 2005
Messages : 152
Détails du profil
Informations personnelles :
Âge : 30
Localisation : France, Hérault (Languedoc Roussillon)

Informations forums :
Inscription : août 2005
Messages : 152
Points : 126
Points : 126
Le truc qui me pose probleme, c'est que dans l'exemple (a la fin), le nom et le port du serveur alternaif sont codés en dur...et moi j'aimerais les recuperer via DB2 à la 1ère connexion.

Dans le doc:
Citation:
After the database administrator specifies the alternate server location, the primary and alternate server locations are returned to the client at connect time.
Ou alors, j'ai pas bien compris...
MadCat34 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/08/2007, 16h36   #4
Membre expérimenté
 
Inscription : mai 2005
Messages : 414
Détails du profil
Informations forums :
Inscription : mai 2005
Messages : 414
Points : 589
Points : 589
Si c'est configuré coté serveur, c'est renvoyé automatiquement par le serveur et stockés dans les informations du driver JDBC client.

http://publib.boulder.ibm.com/infoce...d/cjvclrrt.htm
gregory.broissard est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/08/2007, 16h47   #5
Membre habitué
 
Inscription : août 2005
Messages : 152
Détails du profil
Informations personnelles :
Âge : 30
Localisation : France, Hérault (Languedoc Roussillon)

Informations forums :
Inscription : août 2005
Messages : 152
Points : 126
Points : 126
Donc, en cas de panne du serveur 1, JDBC se debrouille tout seul pour contacter le serveur 2 ?
MadCat34 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 04h30.


 
 
 
 
Partenaires

Hébergement Web