URL: https://linuxfr.org/forums/programmation-perl/posts/fork-et-mysql Title: fork et mysql Authors: arn100 Date: 2005年05月09日T18:19:55+02:00 Tags: Score: 0 Bonjour, J'ai un script qui se connecte à une base de donnée mysql et qui exécute des requêtes (avec le module DBI), jusqu'ici aucun souci. Dans ce script je suis amené à faire un **fork** pour pouvoir exécuter quelques commandes (plutôt longues en termes de temps...) en parrallèle. Mais, à la fin de l'exécution du fils (que je termine par un **exit;** , je perds automatiquement la connexion mysql et le programme père s'arrète du coup également avec le message suivant :
DBD::mysql::st execute failed: MySQL server has gone away at ./fork.pl line 17.
La ligne 17 est l'endroit ou dans le père tente d'exécuter une requête une fois que son fils est "mort". #!/usr/bin/perl -w use DBI; $u = 0; $dbh = DBI->connect( "DBI:mysql:database=mabase;host=localhost.localdomain", £spaces£ £/spaces£"root", "passwd", { 'RaiseError' => 1 } ); #################################################################################### # BOUCLE 1 (BOUCLE "INFINIE") #################################################################################### while (1) { #################################################################################### £spaces£ £/spaces£# REQUETE PRINCIPALE : SELECTION DE LA TABLE UTILISATEUR AVEC TOUS CES CHAMPS #################################################################################### £spaces£ £/spaces£$query = "select * from utilisateur"; £spaces£ £/spaces£$sth = $dbh->prepare($query); £spaces£ £/spaces£$res = $sth->execute; # ICI C'EST LA LIGNE 17 £spaces£ £/spaces£$child = fork; £spaces£ £/spaces£if ( $child == 0 ) { £spaces£ £/spaces£print "Dans le fils\n"; £spaces£ £/spaces£$i = 0; £spaces£ £/spaces£while ( $i < 100 ) { £spaces£ £/spaces£print "Je suis dans le fils" . $u . " " . $i . "\n"; £spaces£ £/spaces£$i = $i + 1; £spaces£ £/spaces£} £spaces£ £/spaces£exit; £spaces£ £/spaces£} £spaces£ £/spaces£$u = $u + 1; } # while(1) FIN BOUCLE 1 (BOUCLE "INFINIE") $sth->finish; $dbh->disconnect; voici la trace de l'exécution : Dans le fils Je suis dans le fils0 0 Je suis dans le fils0 1 Je suis dans le fils0 2 Je suis dans le fils0 3 Je suis dans le fils0 4 Je suis dans le fils0 5 Je suis dans le fils0 6 Je suis dans le fils0 7 Je suis dans le fils0 8 Je suis dans le fils0 9 Je suis dans le fils0 10 Je suis dans le fils0 11 Je suis dans le fils0 12 Je suis dans le fils0 13 Je suis dans le fils0 14 Je suis dans le fils0 15 Je suis dans le fils0 16 Je suis dans le fils0 17 Je suis dans le fils0 18 Je suis dans le fils0 19 Je suis dans le fils0 20 Je suis dans le fils0 21 Je suis dans le fils0 22 Je suis dans le fils0 23 Je suis dans le fils0 24 Je suis dans le fils0 25 Je suis dans le fils0 26 Je suis dans le fils0 27 Je suis dans le fils0 28 Je suis dans le fils0 29 Je suis dans le fils0 30 Je suis dans le fils0 31 Je suis dans le fils0 32 Je suis dans le fils0 33 Je suis dans le fils0 34 Je suis dans le fils0 35 Je suis dans le fils0 36 Je suis dans le fils0 37 Je suis dans le fils0 38 Je suis dans le fils0 39 Je suis dans le fils0 40 Je suis dans le fils0 41 Je suis dans le fils0 42 Je suis dans le fils0 43 Je suis dans le fils0 44 Je suis dans le fils0 45 Je suis dans le fils0 46 Je suis dans le fils0 47 Je suis dans le fils0 48 Je suis dans le fils0 49 Je suis dans le fils0 50 Je suis dans le fils0 51 Je suis dans le fils0 52 Je suis dans le fils0 53 Je suis dans le fils0 54 Je suis dans le fils0 55 Je suis dans le fils0 56 Je suis dans le fils0 57 Je suis dans le fils0 58 Je suis dans le fils0 59 Je suis dans le fils0 60 Je suis dans le fils0 61 Je suis dans le fils0 62 Je suis dans le fils0 63 Je suis dans le fils0 64 Je suis dans le fils0 65 Je suis dans le fils0 66 Je suis dans le fils0 67 Je suis dans le fils0 68 Je suis dans le fils0 69 Je suis dans le fils0 70 Je suis dans le fils0 71 Je suis dans le fils0 72 Je suis dans le fils0 73 Je suis dans le fils0 74 Je suis dans le fils0 75 Je suis dans le fils0 76 Je suis dans le fils0 77 Je suis dans le fils0 78 Je suis dans le fils0 79 Je suis dans le fils0 80 Je suis dans le fils0 81 Je suis dans le fils0 82 Je suis dans le fils0 83 Je suis dans le fils0 84 Je suis dans le fils0 85 Je suis dans le fils0 86 Je suis dans le fils0 87 Je suis dans le fils0 88 Je suis dans le fils0 89 Je suis dans le fils0 90 Je suis dans le fils0 91 Je suis dans le fils0 92 Je suis dans le fils0 93 Je suis dans le fils0 94 Je suis dans le fils0 95 Je suis dans le fils0 96 Je suis dans le fils0 97 Je suis dans le fils0 98 Je suis dans le fils0 99 DBD::mysql::st execute failed: MySQL server has gone away at ./fork.pl line 17. DBD::mysql::st execute failed: MySQL server has gone away at ./fork.pl line 17. si quelqu'un pouvait m'aider...

AltStyle によって変換されたページ (->オリジナル) /