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 :

Lancer des scripts en parallèle


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 317
    Par défaut Lancer des scripts en parallèle
    Bonjour,
    j'ai un programme en python qui reçoit en entrer deux fichiers f1 et f2 et retourne un seul fichier f3.
    je veux faire la meme chose pour plusieurs fichiers de meme type de f1.
    c'est cette commande :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    python mon_prog.py f1 f0 f10
    python mon_prog.py f2 f0 f20
    python mon_prog.py f3 f0 f30
    python mon_prog.py f4 f0 f40
    python mon_prog.py f5 f0 f50
    je veux lancer ça en parallèle.
    Comment je peux faire s'il vous plait?
    J'ai essayé avec GNU Parallel mais ça marche pas je pense la commande est fausse.
    Sinon est-ce que vous avez d'autres idées?
    Merci

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 652
    Par défaut
    Bonjour,

    [...]la commande est fausse
    quelle commande ?
    comment sais-tu qu'elle est "fausse" ?
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 347
    Par défaut
    Bonjour,

    Question: pourquoi ne fais-tu pas ça en python ?

  4. #4
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 317
    Par défaut
    Citation Envoyé par disedorgue Voir le message
    Bonjour,

    Question: pourquoi ne fais-tu pas ça en python ?
    Comment faire ça en Python??
    c'est un programme python sur plusieurs Fichiers avec différentes sorties.

  5. #5
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 317
    Par défaut
    J'ai modifié mon_prog.py.
    la première fois il prend 3 arguments comme vous voyez dans un peu plus haut. je l'ai modifié et il prend qu'un seul argument parce que je n'ai pas pu lancer la commande parallel à plusieurs argument.
    voici ma commande:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cat file.fasta | parallel -j 20 --cat --pipe --block 3M --recstart '>' time python mon_prog.py
    est-ce que vous pouvez m'aider pour que mon prog prend un autre argument(la sortie) comme dans mon cas ? c'est à dire à chaque block de 3M il me donne un fichier de sortie à part?
    Comment faire s'il vous plait?
    Merci

  6. #6
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 317
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    Bonjour,

    quelle commande ?
    comment sais-tu qu'elle est "fausse" ?
    La commande parallel de GNU Parallel. Elle ne marche pas parceque je ne sais pas comment l'utiliser. Je l'ai testé mais ça marche pas. Je ne sais pas le problème.
    D'abord, je voulais savoir est-ce que ma solution de lancer ces commandes est exacte ou pas?
    j'ai essayé de paralléliser avec "|"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    python mon_prog.py f1 f0 f10 | python mon_prog.py f2 f0 f20 | python mon_prog.py f3 f0 f30 | python mon_prog.py f4 f0 f40 | python mon_prog.py f5 f0 f50
    mais je n'ai pas bien compris parce que d'après le web le "|" attend la fin de la première pour commencer la seconde commade donc ce n'est pas parallèle.
    pour moi, je veux toutes le commandes en parallèle.
    Est-ce que c'est possible?

  7. #7
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 102
    Par défaut
    Citation Envoyé par mido1951 Voir le message
    je veux lancer ça en parallèle.
    J'ai pas tout compris (je ne connais pas GNU Parallel), mais, àmha, il suffit de mettre de "&" à la fin de chaque ligne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    python mon_prog.py f1 f0 f10 &
    python mon_prog.py f2 f0 f20 &
    python mon_prog.py f3 f0 f30 &
    python mon_prog.py f4 f0 f40 &
    python mon_prog.py f5 f0 f50 &
    Ensuite, tu tapes la commande jobs et tu verras la liste des tâches qui tournent en parallèle

  8. #8
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 317
    Par défaut
    Je pense "&" attend la fin de la première tâche puis commence la deuxième ... etc
    du coup ils ne sont pas en parallèle.
    n'est-ce pas?

  9. #9
    Membre Expert
    Avatar de Escapetiger
    Homme Profil pro
    Administrateur système Unix - Linux
    Inscrit en
    Juillet 2012
    Messages
    1 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Administrateur système Unix - Linux

    Informations forums :
    Inscription : Juillet 2012
    Messages : 1 559
    Par défaut
    Au contraire, comme écrit à juste titre par jack-ft, le caractère & est explicitement invoqué pour "redonner" la main.

    L’exécution en arrière-plan permet à un utilisateur de lancer une commande et de récupérer immédiatement la main pour lancer « en parallèle » la commande suivante (parallélisme logique). On utilise le caractère & pour lancer une commande en arrière-plan.
    http://eric-sanchis.developpez.com/l...duction#LI-4-2
    I-4-2. Exécution en arrière-plan


    et plus globalement pour le contrôle des tâches :

    http://man.developpez.com/man1/bash/#L26
    26. CONTRÔLE DES TÂCHES
    « Developpez.com est un groupe international de bénévoles dont la motivation est l'entraide au sens large » (incl. forums developpez.net)
    Club des professionnels en informatique

    Liste des balises BB

  10. #10
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 317
    Par défaut
    D'accord si "&" marche en parallèle.
    Alors si vous pouvez m'aider sur mon problème de cette façon.
    donc j'ai deux fichier f.fa et f0.fa et une sortie sortie_prog.fa. le problème ici c'est que f.fa est très gros donc l'idée est de découper f.fa en taille égale par exemple 20 fichiers en tailles égale puis lancer les différents fichiers sur f0.fa(doit etre entier) et biensur pour chaque commande j'ai une sortie différente. Donc le nombre de sortie est égale au nombre de fichiers découper.
    Comment je peux faire ça?
    d'abord il faut faire un programme qui découpe un fichier en des fichiers en tailles egale. est-ce qu'il y a une commande en shell qui fait ça?
    puis lancer en parallèle les commandes sur les différents fichiers découpés.

    Est-ce que vous pouvez m'aider sur ça?
    Merci

  11. #11
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 347
    Par défaut
    Si on reprend ton premier exemple, on peut le faire comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    for i in 1 2 3 4 5
    do
      python mon_prog.py f${i} f0 f${i}0 &
    done
    wait
    Ici, la boucle for do ... done execute en parallèle les commandes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    mon_prog.py f1 f0 f10
    mon_prog.py f2 f0 f20
    mon_prog.py f3 f0 f30
    mon_prog.py f4 f0 f40
    mon_prog.py f5 f0 f50
    puis la commande wait sans paramètres attend que tous les process soient finis pour rendre la main.

    Il ne te reste plus qu'à étudier la commande split pour le découpage de ton fichier initial, car ici, on ne peut pas t'aider puisqu'on ne sait pas si tu veux découper ton fichier en n fichier de taille identique en nombre d'octets ou en nombre de lignes.

Discussions similaires

  1. Réponses: 0
    Dernier message: 25/06/2014, 19h55
  2. [PHP 5.0] Lancer des scripts les uns après les autres
    Par Mandarine dans le forum Langage
    Réponses: 13
    Dernier message: 29/06/2011, 00h27
  3. Réponses: 4
    Dernier message: 10/02/2011, 10h57
  4. Lancer des scripts Ant depuis un plugin Eclipse
    Par Angelinsky7 dans le forum Eclipse Platform
    Réponses: 3
    Dernier message: 05/05/2008, 12h14
  5. [Apache] Lancer des scripts automatiquement
    Par Jim_Nastiq dans le forum Apache
    Réponses: 2
    Dernier message: 16/05/2006, 13h35

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