I have a script running fine under Linux, this is how it works:
use DBI; while (1) { my $dbh = DBI->connect(); # Parent connecting # .. get a job list .. $dbh->disconnect(); # <-- NB! foreach my $job (@jobs) { my $pid = fork(); if (defined $pid) { if ($pid) { $children{$pid} = time; # This is the parent } else { child($job); # This is the child process } } else { logmsg "fork() failed: $!\n"; } } sleep 1; } sub child { my $job = shift; my $dbh = DBI->connect(); # Child connecting # .. do the job .. $dbh->disconnect(); exit; }
I thought I had avoided the potential problems involved with sharing a handle between processes, but much to my surprise ActivePerl on WinXP crashes when the child tries to connect:

DBD::mysql::dr connect failed: handle 1 is owned by thread 183f3e8 not + current thread 260eb64 (handles can't be shared between threads and +your driver may need a CLONE method added) at C:/PERL/site/lib/DBI.pm + line 598. DBD::mysql::dr disconnect_all failed: handle 1 is owned by thread 183f +3e8 not current thread 260eb64 (handles can't be shared between threa +ds and your driver may need a CLONE method added) at C:/PERL/site/lib +/DBI.pm line 677. END failed--call queue aborted.
What handle am I trying to share? Why is the parent $dbh not destroyed before the child process tries to connect?

In reply to DBI and fork() on Win32 by FloydATC

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.