Now I'm at a loss, how did you successfully create a pool of DBI handles with multiple children? I have a pool set, but as soon as my first child ends, DBI tries to clean itself up and kills all my other DBI handles with "end-of-file on communication channel during global destruction" error.
My code (trimmed down):
my %pool;
my %dbhs;
$MAX = 5;
$pm->run_on_start(\&_child_start);
$pm->run_on_finish(\&_child_finish);
my @dbhs = start_dbh();
%pool = map { $_ => 1 } @dbhs;
foreach $i ( @is ) {
($next) = grep ( defined($pool{$_}), @dbhs );
$pid = $pm->start($next) and next;
$sys->set_dbh($dbhs{$next});
sleep(rand(10));
$pm->finish;
}
sub start_dbh() {
%dbhs = map {
$_ => DBI::Connect();
} 0 .. $MAX;
return keys %dbhs;
}
Sys::set_dbh() {
my $this = shift;
$this->{'_dbh-child'} = shift;
}
sub _child_start() {
my ($pid, $ident) = @_;
delete($pool{$ident});
print "**** STARTED: child with PID $pid";
}
sub _child_finish(){
my ($pid, $exit, $ident) = @_;
print "**** FINISHED: child with PID $pid exit cide $exit";
$pool{$ident} = 1;
}
And as soon as the first child dies all my DBI handlers spew out: DBD::Oracle::db DESTROY failed: ORA-03113: end-of-file on communication channel (DBD Error: OCISessionEnd) during global destruction.
-- philip
We put the 'K' in kwality!
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.
|