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

Shell et commandes GNU Discussion :

[Fork] Exécuter des commandes en parallèle


Sujet :

Shell et commandes GNU

  1. #1
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut [Fork] Exécuter des commandes en parallèle
    Bonjour,

    j'ai une petite question pratique shellscript, j'ai ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for server in $(cat servers.list)
    do
    #Connexion au serveur SQL et recherche de resultat
    #Traitement du resultat
    done
    Ce code est exécuté sur plusieurs serveurs (une bonne quinzaine) et de manière itérative, donc c'est très long...

    J'aimerai pouvoir "forker" le contenu de la boucle mais je ne sais pas comment faire... Des idées?


  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 594
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 594
    Points : 19 471
    Points
    19 471
    Par défaut
    Bonjour Arnaud,

    cuuoc (common useless use of cat)

    ainsi :
    Code non-testé : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    yourFunc() {
    serveur=$1
    #Connexion au $serveur SQL et recherche de resultat
    #Traitement du resultat
    }
    while read line; do
       yourFunc "$line" &
    done < servers.list
    ...
    ?

  3. #3
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    Je venais de trouver la réponse en même temps

    Je confirme que ça fonctionne bien !

    Par contre, petite chose, comment je fais pour savoir quand toutes les instances que j'ai lancée en arrière plan sont finies?

    Parce que du coup j'ai de nouveau le prompt SH alors que j'ai des fonctions qui tournent toujours

    de m'aider à élucider ce dernier petit détail

  4. #4
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    J'ai fais un truc du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    for server in $(cut -f1 -d' ' servers.list)
    do
        doIt $server&;
    done
     
    while (( $(ps|grep $0|wc -l|awk '{print $1}') > 1 ))
    do
        sleep 1;
    done
     
    sleep 1;
    Ça fonctionne mais je pense néanmoins que ça doit être très perfectible

  5. #5
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 594
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 594
    Points : 19 471
    Points
    19 471
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #!/bin/bash
    
    while read server reste; do
        doIt $server &
    done <servers.list
    
    while [ $(wc -l <<<"$(grep $0 <(ps -ef))") -gt 1 ] # ou utiliser "$(pgrep $0)"
    do sleep 1
    done
    
    sleep 1

  6. #6
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut

  7. #7
    Membre régulier
    Inscrit en
    Août 2009
    Messages
    107
    Détails du profil
    Informations personnelles :
    Âge : 49

    Informations forums :
    Inscription : Août 2009
    Messages : 107
    Points : 124
    Points
    124
    Par défaut
    Bonjour,

    Avec la commande wait, ce ne serait pas plus simple ? Cette commande attend que tous les jobs d'arrière plan se soient terminé.

  8. #8
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    Citation Envoyé par mongolic Voir le message
    Bonjour,

    Avec la commande wait, ce ne serait pas plus simple ? Cette commande attend que tous les jobs d'arrière plan se soient terminé.
    Pfff trop simple

    J'ai testé, ça fonctionne bien en effet

    Merci !

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 09/10/2008, 16h57
  2. Réponses: 11
    Dernier message: 30/06/2008, 13h15
  3. [Systeme] Exécuter des commandes unix en java
    Par kenny49 dans le forum API standards et tierces
    Réponses: 2
    Dernier message: 12/02/2007, 11h37
  4. Réponses: 2
    Dernier message: 02/11/2004, 06h52

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