NAME
Job::Machine::DB
VERSION
version 0.25
NAME
Job::Machine::DB - Database class for Job::Machine
METHODS
new
my $client = Job::Machine::DB->new(
dbh => $dbh,
queue => 'queue.subqueue',
);
my $client = Job::Machine::Base->new(
dsn => @dsn,
);
serializer
Returns the serializer, default Data::Serializer
listen
Sets up the listener. Quit listening to the named queues. If 'reply' is passed, we listen to the related reply queue instead of the task queue.
Return undef immediately if no queue is provided.
$self->listen( queue => 'queue_name' );
$self->listen( queue => \@queues, reply => 1 );
unlisten
Quit listening to the named queues. If 'reply' is passed, we unlisten to the related reply queue instead of the task queue.
Return undef immediately if no queue is provided.
$self->unlisten( queue => 'queue_name' );
$self->unlisten( queue => \@queues, reply => 1 );
notify
Sends an asynchronous notification to the named queue, with an optional payload. If 'reply' is true, then the queue names are taken to be reply.
Return undef immediately if no queue name is provided.
$self->notify( queue => 'queue_name' );
$self->notify( queue => 'queue_name', reply => 1, payload => $data );
get_notification
Retrieve one notification, if there is one
Retrievies the pending notifications.
my $notifies = $self->get_notification();
The return value is an arrayref where each row looks like this:
my ($name, $pid, $payload) = @$notify;
set_listen
Wait for a notification. The required parameter timeout tells for how long time to wait.
fetch_work_task
Fetch one work task from the task table
insert_task
Insert a row in the task table
set_task_status
Update the task with a new status
fetch_class
Fetch a class
fetch_task
Fetch a task
insert_class
Insert a row in the class table
insert_result
Insert a row in the result table
Argument
data - either a scalar value that will be inserted as the result, or a hashref containing the type and result
fetch_result
Fetch a result using the result id
fetch_first_result
Fetch a result using the task id
fetch_results
Fetch all results of a given task
get_statuses
Fetch all distinct statuses
get_classes
Fetch all classes
get_tasks
Fetch all tasks, joined with the class for a suitable name
revive_tasks
1. Find started tasks that have passed the time limit, most probably because of a dead worker. (status 100, modified < now - max_runtime)
2. Trim status so task can be tried again
fail_tasks
1. Find tasks that have failed too many times (# of result rows > $self->retries
2. fail them (Set status 900)
There's a hard limit (100) for how many tasks can be failed at one time for
performance resons
remove_tasks
3. Find tasks that should be removed (remove_task < now)
- delete them
- log
select_first
Select the first row from the given sql statement
select_all
Select all rows from the given sql statement
where_clause
Very light weight where clause builder
order_by
Very light weight order-by builder
AUTHOR
Kaare Rasmussen <kaare@cpan.org>.
COPYRIGHT
Copyright (C) 2009,2015, Kaare Rasmussen
This module is free software; you can redistribute it or modify it under the same terms as Perl itself.
AUTHOR
Kaare Rasmussen <kaare at cpan dot net>
COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Kaare Rasmussen.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.