use Gearman::OO::Client;
my $client = Gearman::OO::Client->new(
servers => ['127.0.0.1:4730'],
max_queue => 4,
);
logit("connected");
foreach my $id (1..8) {
$client->submit(
func=>'test',
req=>"Data for $id",
complete => sub { logit("completed #$id: @_"); },
error => sub { logit("ERROR #$id! @_"); },
);
logit("added #$id");
}
logit("sync...");
$client->sync();
logit("done.");
####
00:00:00 connected
00:00:00 added #1
00:00:00 added #2
00:00:00 added #3
00:00:00 added #4
00:00:01 completed #1:
00:00:01 completed #2:
00:00:01 added #5
00:00:01 added #6
00:00:02 completed #3:
00:00:02 completed #4:
00:00:02 added #7
00:00:02 added #8
00:00:02 sync...
00:00:03 completed #5:
00:00:03 completed #6:
00:00:04 completed #7:
00:00:04 completed #8:
00:00:04 done.
##
##
package MyJob;
use base 'Gearman::OO::Job';
sub new { my ($class, %args) = @_; bless \%args, $class; }
sub function { 'test'; }
sub complete { my ($self, $data) = @_; logit("$self completed($data)"); }
sub req_data { my ($self) = @_; return $self->{req}; }
use Gearman::OO::Client;
my $client = Gearman::OO::Client->new(
servers => ['127.0.0.1:4730'],
max_queue => 4,
);
logit("connected");
foreach my $id (1..8) {
$client->submit_job(MyJob->new(req => "OO #$id"));
logit("added #$id");
}
logit("sync...");
$client->sync();
logit("done.");