forked from yuxh/gearman-go
a8f0a04c3d
* Common race condition is fixed by identifying that Client.respHandler can be completely removed since all respHandler operations (get, put and invocation) can be moved into the Client.processLoop goroutine, meaning that zero locking is required. This race condition resulted in a deadlock that was resolved by the response timeout at the end of client.Do, returning ErrLostConn * Rare race condition is fixed by changing responseHandlerMap.get to .getAndRemove. This race condition resulted in the innerHandler for a new dtJobCreated assigned in client.Do overriding a stale older dtJobCreated request, and the newer innerHandler being removed by an older dtJobCreated in client.processLoop > client.handleInner. When the newer dtJobCreated response was received, the handler for it had already been deleted. This was resolved by the response timeout at the end of client.Do, returning ErrLostConn
34 lines
728 B
Perl
34 lines
728 B
Perl
#!/usr/bin/perl
|
|
|
|
# Runs 20 children that expose "PerlToUpper" before returning the result.
|
|
|
|
use strict; use warnings;
|
|
use constant CHILDREN => 20;
|
|
use Time::HiRes qw(usleep);
|
|
use Gearman::Worker;
|
|
|
|
$|++;
|
|
my @child_pids;
|
|
for (1 .. CHILDREN) {
|
|
if (my $pid = fork) {
|
|
push @child_pids, $pid;
|
|
next;
|
|
}
|
|
eval {
|
|
my $w = Gearman::Worker->new(job_servers => '127.0.0.1:4730');
|
|
$w->register_function(PerlToUpper => sub { print "."; uc $_[0]->arg });
|
|
$w->work while 1;
|
|
};
|
|
warn $@ if $@;
|
|
exit 0;
|
|
}
|
|
|
|
$SIG{INT} = $SIG{HUP} = sub {
|
|
kill 9, @child_pids;
|
|
print "\nChildren shut down, gracefully exiting\n";
|
|
exit 0;
|
|
};
|
|
|
|
printf "Forked %d children, serving 'PerlToUpper' function to gearman\n", CHILDREN;
|
|
sleep;
|