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

avec Java Discussion :

Lancer en parallèle la même méthode


Sujet :

avec Java

  1. #1
    Membre régulier
    Inscrit en
    Mars 2005
    Messages
    319
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 319
    Points : 80
    Points
    80
    Par défaut Lancer en parallèle la même méthode
    Salut,

    J'ai un code qui exécute du sql contenu dans un fichier.
    Ce que je fais, c'est que je lis le fichier, je le met dans un string
    et ensuite je met le contenu du string dans un tableau.

    Je boucle ensuite sur le tableau,
    et pour chaque élément du tableau , j'appelle la méthode.

    Le truc est que si j'ai 10 éléments dans le tableau,
    et que le 1ere met 5 minutes,
    il faut attendre que le 1er se termine pour que les autres se suivent.
    Je voulais savoir s'il était possible,
    de lancer n-fois la méthode en parallèle ?

    Merci de votre aide.

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Possible, oui, voulu, non. Si ton fichier contient une série d'opération à faire dans la base de données, il est peu probable d'avoir un résultat correct en faisant ces instructions dans le désordre et dans des transactions distinctes...

    Le plus propre est de revoir ces commandes SQL pour qu'elles soient plus performantes . Une instruction SQL qui met 10 minutes à s'exécuter, c'est une instruction sql qui mérite d'être un peu revue

  3. #3
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  4. #4
    Membre régulier
    Inscrit en
    Mars 2005
    Messages
    319
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 319
    Points : 80
    Points
    80
    Par défaut
    en faite,
    quand je dis instruction SQL,
    je parle de requête, l'ordre n'a pas d'importance.
    Je peux avoir n requête dans mon fichier,
    et il se peut qu'une de ses requêtes mettent 10 minutes voire plus.
    Dans la mesure ou je ne serait pas forcément la personne qui va écrire ses requêtes.

    L'idée en faite, c'était de pouvoir lancer tout en parallèle,
    comme ça les requêtes longues ne pénalise pas les rapides.

  5. #5
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Dans ce cas, comme suggéré, utilise un ExecutorService. Attention cependant! Tu ne peux pas te contenter d'avoir chaque Future exécuter un simple "connection.createStatement". Tu devra aussi garantir que chaque Thread aie sa propre connection. Le plus simple pour ça c'est d'avoir un Connection pool disponible et d'avoir, dans chaque Futula fin.

  6. #6
    Membre régulier
    Inscrit en
    Mars 2005
    Messages
    319
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 319
    Points : 80
    Points
    80
    Par défaut
    C'est pas aussi simple que ça en faite.

    J'utilise ceci en faite
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ConnexionBase = ConnexionBase(DRIVER,CONNECTION,USER,PASSWD);
    preparedStatement = ConnexionBase.prepareStatement(reqSQL);
    Resultat rs = preparedStatement.executeQuery();
    ce que tu me dis, c'est que chaque thread doit avoir sa propre connexion.

    Toute la connexion et l'exécution de la requête est contenu dans une méthode, execReq.

    Si dans mon code, chaque fois que je lis une ligne du tableau,
    je crée un nouveau execReq :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Creq execReq= new Creq ();
    Si j'ai 3 lignes dans le tableau et donc 3 requêtes,
    je crée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Creq execReq1= new Creq ();
    execReq1.lanceReq(reqSQL);
    Creq execReq2= new Creq ();
    execReq2.lanceReq(reqSQL);
    Creq execReq3= new Creq ();
    execReq3.lanceReq(reqSQL);
    Je sais pas si c'est très propre et en y réfléchissant bien,
    comme je boucle ,j'imagine que cela revient au même.
    Il n'exécutera pas en parallèle.
    Dommage qu'on puisse pas lancer en tâche de fond comme sous unix.

  7. #7
    Membre régulier
    Inscrit en
    Mars 2005
    Messages
    319
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 319
    Points : 80
    Points
    80
    Par défaut
    Finalement,
    en y réfléchissant bien,
    je pense pas que ce soit une bonne solution.
    Supposons que 10 grosses requêtes tournent en parallèle,
    elles vont faire explosé le tablespace TEMP et elles vont saturées la mémoire.
    Autant qu'elles tournent une après l'autre.
    Par contre, le système de pool de connexion, sa m'intéresse;

  8. #8
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    C'est pour ça qu'on te dit d'utiliser un ExecutorService.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Creq execReq1= new Creq ();
    executorService.submit(execReq1);
    Creq execReq2= new Creq ();
    executorService.submit(execReq2);
    Creq execReq3= new Creq ();
    executorService.submit(execReq3);
    executorService.awaitTerminaison();
    Je ne vois pas ce que unix viens faire dans l'histoire

    Pour le reste, c'est assez bizarre un Oracle qui ne supporterait pas de faire 10 grosse requêtes en parallèle

  9. #9
    Membre régulier
    Inscrit en
    Mars 2005
    Messages
    319
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 319
    Points : 80
    Points
    80
    Par défaut
    Je faisais allusion à unix car si j'aurai eu à faire cela en ksh.
    J'aurai crée un script d'exécution de requête : lance_req.ksh.
    Et chaque fois que je boucle,
    je fais un fork et je lance mon script en nohup lance_req.ksh &
    et comme cela je peux avoir n-script donc n-requête qui tourne en parallèle.

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 10/02/2007, 20h30
  2. lancer deux fonctions en même temps
    Par youp_db dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 28/09/2006, 12h11
  3. Lancer plusieurs .bat en même temps
    Par mdriesbach dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 22/09/2006, 16h37
  4. Réponses: 23
    Dernier message: 08/02/2006, 09h15
  5. Lancer deux sons en même temps...
    Par Julien_riquelme dans le forum API, COM et SDKs
    Réponses: 1
    Dernier message: 03/05/2003, 17h00

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