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

Langage Perl Discussion :

cigwyn uninitialized value


Sujet :

Langage Perl

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 198
    Par défaut cigwyn uninitialized value
    Bonjour,

    Testant sous cigwin en attendant de mettre en production sur une station linux. Je test des connections SSH vers des routeurs et switch en utilisant le module Net::SSH::Any

    Quand la connexion est ok, pas de souçis, je récupére les valeurs que je souhaite.
    Quand la connexion ne peux pas se faire, j'ai un message d'erreur explicite (même si pas celui que j'ai indiqué) mais j'ai des lignes en plus dont je voudrais me débarrasser pour que ca soit plus présentable pour un rapport.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    use strict;
    use warnings;
    use Data::Dumper;
    use feature 'say';
    no warnings 'uninitialized';
     
    use Net::SSH::Any;
     
    my $host = '172.20.98.199';
    my $user = 'admin';
     
    my %param=(
        user => $user,
        password=>'cisco',
        timeout => 2,
        #port => '22'
        );
     
    use Net::SSH::Any;
     
    my $ssh = Net::SSH::Any->new($host,%param);
    $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;
     
    my @out = $ssh->capture("show running");
     
    print "@out";
    Résultat:
    $ perl test.pl
    ssh: connect to host 172.20.98.199 port 22: Connection timed out
    Use of uninitialized value $pid in waitpid at /usr/lib/perl5/site_perl/5.22/Net/SSH/Any/OS/_Base.pm line 206.
    Use of uninitialized value $pid in numeric eq (==) at /usr/lib/perl5/site_perl/5.22/Net/SSH/Any/OS/_Base.pm line 210.
    Use of uninitialized value $pid in concatenation (.) or string at /usr/lib/perl5/site_perl/5.22/Net/SSH/Any/OS/_Base.pm line 220.
    Use of uninitialized value $? in scalar assignment at /usr/lib/perl5/site_perl/5.22/Net/SSH/Any/Backend/_Cmd.pm line 124.


    Couldn't establish SSH connection: $host => ne s'affiche pas, mais surtout je voudrais ne pas afficher les lignes en bleues

    J'ai testé en commentant la ligne "use warnings" mais ca ne change rien.

    Une idée?

    Merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Billets dans le blog
    1
    Par défaut
    Il y a sans doute une meilleure solution, mais tu peux toujours essayer de filtrer tes erreurs:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    print for grep { not /Use of uninitialized value/ } @out;

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 198
    Par défaut
    Bonjour Lolo,

    les messages d'erreurs sont du à la commande :

    my $ssh = Net::SSH::Any->new($host,%param);
    $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;

    ou j'ai volontairement mis une @IP non joignable pour faire un test.

    Ta solution ne fonctionnera pas dans le cas présent puisque @out est le résultat d'une commande avec une connexion réussie.

  4. #4
    Expert confirmé

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    3 577
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2009
    Messages : 3 577
    Par défaut
    les messages d'erreurs sont du à la commande :

    my $ssh = Net::SSH::Any->new($host,%param);
    $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;
    Non, ils sont dus à la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my @out = $ssh->capture("show running");
    Ces affichages (en rouge) sont des warnings que tu peux ignorer ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    my $ssh = Net::SSH::Any->new($host,%param);
    $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;
    my @out;
    {
      local $SIG{__WARN__} = sub {};
      @out = $ssh->capture("show running");
      $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;
    }
    print "@out" if @out;
    Par contre, je ne sais pas comment capturer le message "ssh: connect to host 172.20.98.199 port 22: Connection timed out", également généré par cette ligne de code.

  5. #5
    Membre éprouvé
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Juillet 2014
    Messages
    84
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2014
    Messages : 84
    Par défaut
    Citation Envoyé par Philou67430 Voir le message
    Par contre, je ne sais pas comment capturer le message "ssh: connect to host 172.20.98.199 port 22: Connection timed out", également généré par cette ligne de code.
    En redirigeant le STDOUT et STDERR ? (proposition)

  6. #6
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 198
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    my $ssh = Net::SSH::Any->new($host,%param);
    $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;
    my @out;
    {
      local $SIG{__WARN__} = sub {};
      @out = $ssh->capture("show running");
      $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;
    }
    print "@out" if @out;
    Effectivement ca donne comme résultat :

    -bash-4.3$ perl test.pl
    ssh: connect to host 172.20.98.199 port 22: Connection timed out
    Couldn't establish SSH connection: 172.20.98.199slave process exited unexpectedly with error code 255 at test.pl line 28.
    il faut que je regarde ton bloc Philou car je ne connais pas
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    {
      local $SIG{__WARN__} = sub {};
      @out = $ssh->capture("show running");
      $ssh->error and die "Couldn't establish SSH connection: $host" . $ssh->error;
    }
    je vais tester la redirection comme piste de STDERR.

    Le message de timeout doit être un message de openssh

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    -bash-4.3$ ssh admin:cisco@172.20.98.199
    ssh: connect to host 172.20.98.199 port 22: Connection timed out

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

Discussions similaires

  1. Use of uninitialized value in pattern match (m//)
    Par Vladkergan dans le forum Langage
    Réponses: 4
    Dernier message: 13/01/2008, 19h25
  2. Use of uninitialized value in string ne at
    Par Gad29 dans le forum Programmation et administration système
    Réponses: 4
    Dernier message: 09/05/2007, 13h49
  3. [USE STRICT] uninitialized value in print ...
    Par pop_up dans le forum Langage
    Réponses: 4
    Dernier message: 24/04/2006, 14h18
  4. uninitialized value in print - recup données de BDD
    Par pimousse_on_ice dans le forum SGBD
    Réponses: 13
    Dernier message: 24/02/2006, 10h42
  5. [langage] Use of uninitialized value
    Par Batou dans le forum Langage
    Réponses: 2
    Dernier message: 21/02/2005, 10h28

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