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 :

Récupérer les retours d'un script exécuté en ssh


Sujet :

Shell et commandes GNU

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2016
    Messages : 5
    Par défaut Récupérer les retours d'un script exécuté en ssh
    Bonjour à tous

    J'ai un petit souci avec deux script .bash

    Mon premier script effectue une connexion ssh et provoque l’exécution d'un deuxième script (installation de paquets) sur la machine distante
    Il fonctionne comme suit:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ssh "$USER"@"$IP" 'bash -s < ScriptInstallation.bash
    Je voudrais pouvoir récupérer des codes d'installations dans un fichier .txt sur ma machine mais je ne trouve pas la commande pour ça
    J'ai essayé ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ssh "$USER"@"$IP" 'bash -s < ScriptInstallation.bash >> LogInstallations.txt
    Mais cela renvoi toutes les sorties dans le .txt
    J'ai déjà demandé de l'aide et on m'a proposé des solutions comme suit, avec un code en début de ligne dans mon ScriptInstallation.bash

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ssh "$USER"@"$IP" 'bash -s' <ScriptInstallation.bash | awk '/^==>/{sub"^==>", ""); print > "LogInstallations.txt"; next} {print}'
    le "==>" représente le code en début de ligne, elle est écrite de cette façon dans le script :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     echo "==> $Nomdelamachine $IP : INSTALLATION RÉUSSIE"
    Je précise que mon ScriptInstallation.bash fait 400 lignes donc il n'est pas possible de le mettre dans une seule commande.
    J'ai aussi essayé avec des "grep" et plusieurs combinaison avec "awk" mais sans succès.

    Quelqu'un aurait-il une solution??

    Merci

  2. #2
    Membre expérimenté Avatar de silfun1
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mars 2015
    Messages
    135
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2015
    Messages : 135
    Par défaut
    Salut Virtual,

    J'ai eu à faire quelque chose de similaire.
    Voici la ligne que j'utilise pour récupérer la sortie de la commande SSH:

    SSHBIN="/usr/bin/ssh"
    USERNAME="webuser"
    IP="10.10.25.45"
    CMD="find / -type f -name "*.crt" 2>/dev/null"
    SCRIPTFILE="getinfo.sh"

    # Pour executer une commande =
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TEXTRESULT=$($SSHBIN -n -o StrictHostKeyChecking=no $USERNAME@$IP "$CMD")

    # Pour executer un script, je rajoute une étape qui consiste à le copier sur le serveur cible, puis je l'execute.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    scp -o StrictHostKeyChecking=no $SCRIPTFILE $USERNAME@$IP:$SCRIPTFILE
    TEXTRESULT=$($SSHBIN -n -o StrictHostKeyChecking=no $USERNAME@$IP "$SCRIPTFILE")
    Sylvain

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2016
    Messages : 5
    Par défaut
    Merci de ta réponse Sylvain mais j'ai du mal à comprendre le fonctionnement de ta commande.

    Peux-tu m'expliquer davantage, sachant que je dois récupérer des infos différentes en fonction du script et de son déroulement (installation ok, avec problème, échouée)?

    Merci

  4. #4
    Expert confirmé Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 041
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 041
    Par défaut
    salut,

    je vois pas trop où est le problème perso :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ssh user@host "bash < script.sh" | grep "^==>"
    par contre le -o StrictHostChecking=no c'est plutôt pas une bonne idée, en tous cas ça n'apporte rien de plus ici
    (@silfun1, si c'est parce que tu as changé de clé tu aurais meilleur compte de l'identifier et la supprimer de ton ~/.ssh/known_hosts, et éventuellement en rajoutant HashKnownHosts no à ton éventuel ~/.ssh/config pour te simplifier la vie la fois d'après)

  5. #5
    Membre expérimenté Avatar de silfun1
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mars 2015
    Messages
    135
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2015
    Messages : 135
    Par défaut
    Re bonjour,

    @Virtual : Voici quelques explication sur mes commandes:

    Copie de mon script sur mon serveur distant


    Execution de mon script fraichement copié, sur mon serveur distant et récupération de la sortie standard dans ma variable nommée TEXTRESULT
    • commande = TEXTRESULT=$(/usr/bin/ssh -n titi@mondev "./getinfo.sh")
    • Test =
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      [01-07-2016 15:35:08 titi@monserveur:~/tmp]$   TEXTRESULT=$(/usr/bin/ssh -n titi@mondev "./getinfo.sh")
      [01-07-2016 15:35:08 titi@monserveur:~/tmp]$   echo $TEXTRESULT
      /home/titi total 88 drwxr-xr-x 3 titi exploit 40960 sept. 30 2015 cronlog -rw------- 1 titi exploit 1981 oct. 7 2015 dead.letter -rwxr-xr-x 1 titi exploit 10 juil. 1 15:34 getinfo.sh


    @BufferBob : Effectivement, ce n'est pas très propre. J'utilise cela pour éviter les erreur pour les nouveaux serveurs. Ces derniers n'étant pas encore dans le known_hosts

    ssh titi@mondev "bash < getinfo.sh"
    et
    ssh titi@mondev "bash -s < getinfo.sh"
    = Fonctionnent bien. Mais pour une raison que j'ai oublié, ça ne fonctionnait pas tout le temps. Bref, c'est pour ça que j'ai fini par utilisé les commandes citées çi-dessus.

    Le parametre "-n" (dans ssh -n xxxxxx) = Ca m'a sauvé la vie dans le cas ou on utilise la commande ssh dans une boucle (si on a plusieurs serveurs).

    Sylvain

  6. #6
    Modérateur
    Avatar de ggnore
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 472
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 472
    Par défaut
    Tu as essayé ansible ? C'est bien adapté pour installer sur des serveurs.
    Toutes les vertus des hommes se perdent dans l’intérêt comme les fleuves se perdent dans la mer.
    N'oubliez pas de consulter les FAQ Linux et les cours et tutoriels Linux

Discussions similaires

  1. récupérer les retours à la ligne d'un textarea
    Par epeichette dans le forum jQuery
    Réponses: 4
    Dernier message: 08/04/2011, 12h13
  2. Récupérer :les arguments d'un script
    Par sliderman dans le forum Linux
    Réponses: 2
    Dernier message: 06/04/2008, 17h56
  3. Réponses: 7
    Dernier message: 05/04/2007, 16h15
  4. Réponses: 10
    Dernier message: 02/04/2007, 10h42
  5. Réponses: 4
    Dernier message: 15/05/2006, 15h54

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