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

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    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 : 195
    Points : 121
    Points
    121
    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
    Points : 12 256
    Points
    12 256
    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 régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    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 : 195
    Points : 121
    Points
    121
    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 : 58
    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
    Points : 5 753
    Points
    5 753
    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.
    Plus j'apprends, et plus je mesure mon ignorance (philou67430)
    Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book)
    Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé
    Si c'est utile, say

  5. #5
    Membre habitué
    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
    Points : 197
    Points
    197
    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 régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    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 : 195
    Points : 121
    Points
    121
    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

  7. #7
    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 : 58
    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
    Points : 5 753
    Points
    5 753
    Par défaut
    Je n'ai pas réussi, en mode debug, à trouver l'instruction qui provoque l'affichage de l'erreur de timeout. La seule certitude que j'ai, c'est que cette erreur est générée par un sous-processus lancé en parallèle du processus principal.
    Plus j'apprends, et plus je mesure mon ignorance (philou67430)
    Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book)
    Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé
    Si c'est utile, say

  8. #8
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    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 : 195
    Points : 121
    Points
    121
    Par défaut
    C'est bon j'ai trouvé l'information pour le bloc

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      local $SIG{__WARN__} = sub {};
    Ca peut aider

  9. #9
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    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 : 195
    Points : 121
    Points
    121
    Par défaut
    Merci Philou

    Je pense que je vais garder le messager d'erreur d'origine assez explicite.
    J'en ferais un plus si d'autre cas ce présente.

    Déjà le bloc pour supprimer les warning générés par une commande permet de bien nettoyer et géré l'affichage pour la suite.

  10. #10
    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
    Points : 12 256
    Points
    12 256
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Philou67430 Voir le message
    Je n'ai pas réussi, en mode debug, à trouver l'instruction qui provoque l'affichage de l'erreur de timeout.
    Peut-être qu'avec la technique expliquée ici: http://perl.developpez.com/faq/perl/...tialized-value...

  11. #11
    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 : 58
    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
    Points : 5 753
    Points
    5 753
    Par défaut
    @Lolo : quand je dis que je n'ai pas réussi, c'est surtout que je n'ai pas passé assez de temps (parce que je n'en avais pas) pour trouver Cela dit, je ne connais pas bien le module DB, et l'astuce donnée est intéressante. A vrai dire, dans le cas présent, je ne suis même pas sûr que le message est émis par warn ! Je vais voir.
    @Caramon : l'instruction $SIG{__WARN__} = sub {} permet d'ignorer les warning. Mais tu auras sans doute compris qu'aui lieu de ça, tu peut aussi les traiter (à l'intérieur du sub). Dans ce cas, le texte de la warning a émettre se trouve dans le premier paramètre de la fonction ($_[0]).
    Plus j'apprends, et plus je mesure mon ignorance (philou67430)
    Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book)
    Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé
    Si c'est utile, say

  12. #12
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    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 : 195
    Points : 121
    Points
    121
    Par défaut
    @Philou
    J'étais tombé sur cette page en cherchant l'explication de ton bloc
    https://perlmaven.com/how-to-capture...rnings-in-perl
    Pas encore fait les test pas manque de temps.

    @Lolo
    vu vite fait le lien mais pas encore testé par manque de temps

  13. #13
    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 : 58
    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
    Points : 5 753
    Points
    5 753
    Par défaut
    Très bon le blog de Gabor J'ai pas trop le temps de lire ses newsletters en ce moment, dommage
    Plus j'apprends, et plus je mesure mon ignorance (philou67430)
    Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book)
    Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé
    Si c'est utile, say

+ 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