Flitz | Bonjour à tous. J'ai besoin d'aide.
Je dispose d'un script qui est utilisé pour sauver les configurations des éléments d'un réseau. Ce script utilise un autre script (en expect) qui sert à se connecter aux éléments. Lorsque je lance le script "ScriptSaveEAConfig.pl" (qui est mon script de base) manuellement, tout fonctionne correctement. Donc je suis dans le répertoire X et je le lance de là, à ce moment tous les fichiers de config se sauve dans le répertoire d'où j'ai lancé manuellement mon script.
J'aimerais lancé ce script tous les jours à une certaine heure (parmis d'autres scripts). Pour ce faire je dispose d'un script scheduler appelé x.pl qui est lancé toutes les minutes par la CRON. x.pl détermine à chaque minute quel script il doit lancer. Lorsque j'incorpore "ScriptSaveEAConfig.pl" dans x.pl à ce moment ça ne fonctionne plus.
Plus précisement, "ScriptSaveEAConfig.pl" est bien lancé (car il crée bien les fichiers de sauvegarde) mais le script expect n'est pas lancé (car les fichiers sont vides et c'est lui qui est sensé me fournir la config).
Il est à noter que le x.pl est lancé du répertoire X alors que ScriptSaveEAConfig est lancé de X/save_ea.
Je vous joints le code. Pourriez-vous me dire svp ce qui cloche quand je passe par x.pl ? Je sèche vraiment là !
Voici la partie du code de ScriptSaveEAConfig qui est utile
Code :
- chdir('/usr/local/bin/routeur/save_ea/') || die ("erreur chdir" );
- #open SHOWRUN, "./telnetnomem.exp $ip |";
- @tableau = `$BinPath/save_ea/telnetnomem.exp $ip`;
- my $dernier_index = @tableau;
- open (SAVE, ">$save" );
- my $flag = 0;
- #while (my $ligne = <SHOWRUN> ){
- for($xx=0;$xx < $dernier_index ; $xx++){
- my $ligne = $tableau[$xx];
- if ($ligne =~ m/Building configuration/){$flag = 1;}
- if ($ligne =~ m/#exit/){$flag = 0; last;}
- if ($flag == 0){next;}
- if ($flag == 1){print SAVE ($ligne); next;}
- }
- #close SHOWRUN;
- close SAVE;
|
et voici celle de x.pl (scheduler lancé une fois par minute qui appelle le script de save)
Code :
- $sql_statement ="UPDATE donnee_reseau.Scheduler SET val = init WHERE script_type = 'ScriptSaveEA';";
- $sth = $dbh->query($sql_statement);
- $tt=1;
- ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime(time);
- $ts = "date : $mday-$mon-$year --- time : $hour-$min-$sec";
- $sql_statement ="INSERT INTO donnee_reseau.LogTable (`time`, `action`, `commentaire`) VALUES ('$ts', 'ScriptSaveEAConfig.pl', 'Lancement de ScriptSaveEAConfig');";
- $sth = $dbh->query($sql_statement);
- system ("$BinPath/save_ea/ScriptSaveEAConfig.pl -o=nomem" );
|
je vous remercie d'avance pour toutes vos réponses |