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 :

Ce Script perl est il fonctionnel?


Sujet :

Langage Perl

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 152
    Par défaut Ce Script perl est il fonctionnel?
    Bonjour,

    J'ai laissé faire un script perl et j'aimerai savoir si ce dernier regroupe tout ce que j'ai demandé.

    Je voulais que ce script tourne en tache de fond tel un daemon.

    Il doit se connecter à ma base mysql contenant près de 70000 adresses ip, et tester les adresses par aquet de 600 en multithreading.

    Si le serveur distant répond, on le laisse dans ma base et on update le champ "Status" à "Verified et le champ "LastCheck" à l'heure actuelle.

    Si le serveur distant ne réponds pas, on le supprime de la base.

    D'après ce que je vois, concernant les update, cela a été appliqué...Par contre au niveau du multithreading, je ne crois pas...Si je comprends, le script ne sélectionne que les 600 premières entrées et les testent. Mais je ne crois pas que c'est en multithread, ni toutes les adresses de la base ou bien?

    Merci de m'apporter tous vos commentaires sur ce script...

    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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    #!/usr/bin/perl -w
     
    use DBI;
    use Date::Format;
    use Net::Telnet;
    sub testaddress($$);
    sub update_ip($);
    sub remove_ip($);
    #Params=================
    my $pingtimeout= '25'; #timeout 25 secs..
    my $iplimit = '600'; #number of address to test.
    my $sqlhost="localhost"; # mysql server
    my $sqluser = ""; #mysql username 
    my $sqlpass = ""; #root passwd
    my $sqldb = ""; #ip adress db
    my $sqltable = "listeIp"; 
    #Fin params=============
    my $dbh = DBI->connect("DBI:mysql:database=$sqldb:host=$sqlhost",$sqluser,$sqlpass) or die ("Cannot connect to db");
    my $getip = $dbh->prepare("select Ipadress, port from listeIp limit $iplimit");
    $getip->execute() or die "Cannot get IP list. \n";
    while(my $result = $getip->fetchrow_hashref()){
        my $ip = $result->{"Ipadress"};
        my $port = $result->{"port"};
        my $res = testaddress($ip,$port);
        if(!$res){
    	remove_ip($ip);
        }
        else{
    	update_ip($ip);
        }
    }
    $dbh->disconnect();
    exit;
     
    sub testaddress($$){
        my $ok=0;
        my ($ip,$port)=@_;
        $p = new Net::Telnet (Host    => $ip,
    			  Port    => $port,
    			  Timeout => $pingtimeout,
    			  Errmode => "return");
        return($p);
    }
     
    sub remove_ip($){
        my ($ip)=@_;
        my $rem = $dbh->prepare("delete from listeIp where Ipadress='$ip'");
        $rem->execute() or die "Cannot delete $ip from IP table\n";
    }
    sub update_ip($){
        my ($ip)=@_;
        my $update_lc = $dbh->prepare("update listeIp set LastCheck=Now() where Ipadress='$ip'");
        $update_lc->execute() or die "Cannot update LastCheck value for $ip";
        my $update_stat = $dbh->prepare("update listeIp set Status='Verified' where Ipadress='$ip'");
        $update_stat->execute() or die "Cannot update Status for $ip";
    }

  2. #2
    Expert confirmé
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Par défaut
    Ce script ne vérifie jamais que les 600 premières adresses IP de la base, il les vérifie séquentiellement (ici le multithread est inutile et trop lourd, mais l'approche correcte est de faire les tests simultanément en asynchrone, ce n'est pas ce qu'il fait), les suppressions et les updates de la base sont exécutés de façon plus que suboptimale, visiblement c'est le code de quelqu'un de pas très bon en Perl, d'assez nul en SQL, ne connaissant pratiquement rien à DBI et aux bases de données en général (et également d'un menteur s'il a prétendu que son code remplissait tes conditions).

    Ah, j'oubliais : il ne tourne pas en tâche de fond comme un démon mais ce n'est pas un vrai problème, c'est plutôt un script à lancer périodiquement avec un cron de toute façon.

    --
    Jedaï

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 152
    Par défaut
    Bonjour Jedai,

    C'est bien ce que je pensais...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Ce script ne vérifie jamais que les 600 premières adresses IP de la base, il les vérifie séquentiellement (ici le multithread est inutile et trop lourd, mais l'approche correcte est de faire les tests simultanément en asynchrone, ce n'est pas ce qu'il fait)
    Ok, mais ma base contient tout de même 70000 ip environs et tout au long de la journée,de nouvelles ip sont ajoutées. Un traitement séquentiel prendrait une éternité...C'est ce que j'avais fait en php. Il faudrait tester 600 adresses à la fois afin de savoir si tous les serveurs distant répondent en l'espace de 1h40 minutes, puis retester tous ces serveurs etc... Sinon, quelle différence entre le multithread et l'asynchrone, tous les 2 permettant de tester en simultané...?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    les suppressions et les updates de la base sont exécutés de façon plus que suboptimale, visiblement c'est le code de quelqu'un de pas très bon en Perl, d'assez nul en SQL, ne connaissant pratiquement rien à DBI et aux bases de données en général (et également d'un menteur s'il a prétendu que son code remplissait tes conditions).
    La, moi je n'y connais rien, en comparant avec php, il est vrai que je pensais que de ce côté le boulot était bien fait...mais visiblement il n'en est rien. En plus après avoir installé, cela retourne une erreur 500.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Ah, j'oubliais : il ne tourne pas en tâche de fond comme un démon mais ce n'est pas un vrai problème, c'est plutôt un script à lancer périodiquement avec un cron de toute façon.
    La encore, je ne sais pas ce qui est le mieux...Mais comme dit plus haut, dès que le test sur toutes les ip à été fait, il faut immédiatement que le script reteste les ip restantes + les nouvelles ip qui se seront rajouté entre temps.

    En tout cas merci pour cette réponse et je vais espérer tombé sur quelqu'un de plus compétent...car moi je ne saurais faire ce script en perl et je ne sais pas les modules qu'il faut utiliser. Je reposterai donc certainement

Discussions similaires

  1. Comment savoir si un script perl est terminé ?
    Par Krys006 dans le forum Programmation et administration système
    Réponses: 15
    Dernier message: 21/07/2012, 15h21
  2. Le répertoire courant de mon script perl est " / " ?!
    Par sailing-port dans le forum Web
    Réponses: 3
    Dernier message: 26/11/2008, 15h29
  3. [langage] script perl cmd system
    Par kacedda dans le forum Langage
    Réponses: 4
    Dernier message: 02/05/2003, 09h45
  4. [langage] awk et sed dans script perl
    Par scoti dans le forum Langage
    Réponses: 3
    Dernier message: 07/04/2003, 18h26
  5. Réponses: 2
    Dernier message: 11/07/2002, 08h31

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