NAME
Minion::Notifier - Notify listeners when a Minion task has completed
SYNOPSIS
use Mojolicious::Lite;
plugin Minion => { Pg => 'posgressql://...'};
plugin 'Minion::Notifier';
app->minion->add_task( doit => sub { ... } );
any '/doit' => sub {
my $c = shift;
my $id = $c->minion->enqueue(doit => [...]);
$c->minion_notifier->on(job => sub {
my ($notifier, $job_id, $message) = @_;
return unless $job_id eq $id;
$c->render( text => "job $id: $message" );
});
};
DESCRIPTION
Although Minion is a highly capable job queue, it does not natively have a mechanism to notify listeners when a job has finished or failed. Minion::Notifier provides this feature using pluggable Transport backends. Currently supported are Postgres, Redis, and WebSocket. Postgres support requires Mojo::Pg and Redis requires Mojo::Redis2. WebSockets are native to Mojolicious but you need a broker to manage the connections; Mercury is the author's suggested WebSocket message broker.
Note that this is an early release and the mechansim for loading plugins, especially third-party plugins is likely to change. Also note that due to the use of messaging buses, the order of events is not guaranteed especially on very fast jobs.
EVENTS
Minion::Notifier inherits all events from Mojo::EventEmitter and emits the following new ones.
enqueue
$notifier->on(enqueue => sub { my ($notifier, $job_id) = @_; ... });
Emitted whenever any job is enqueued (typically having a state of "inactive"). Note that the event is not repeated as an argument, though this is subject to change.
dequeue
$notifier->on(dequeue => sub { my ($notifier, $job_id) = @_; ... });
Emitted whenever any job is dequeued for processing (typically having a state of "active"). Note that the event is not repeated as an argument, though this is subject to change.
job
$notifier->on(job => sub { my ($notifier, $job_id, $event) = @_; ... });
Emitted on any event from the backend for all jobs. The events are currently "enqueue", "dequeue", "finished", and "failed".
job:$id
$notifier->on("job:1234" => sub { my ($notifier, $job_id, $event) = @_; ... });
Emitted on any message from the backend for specific jobs. Note that the id is still passed so that you may reuse callbacks if desired. The events are currently "enqueue", "dequeue", "finished", and "failed".
Users of this event are encouraged to carefully consider what race conditions may exist in the act of subscribing to it. For example, Minion::enqueue
will emit the "enqueue" event before it even returns the job's id. For this reason, this event is discouraged and may be deprecated/removed in a future release.
finished
$notifier->on(finished => sub { my ($notifier, $job_id) = @_; ... });
Emitted whenever any job reaches a state of "finished". Note that the event is not repeated as an argument, though this is subject to change.
failed
$notifier->on(failed => sub { my ($notifier, $job_id) = @_; ... });
Emitted whenever any job reaches a state of "failed". Note that the event is not repeated as an argument, though this is subject to change.
ATTRIBUTES
Minion::Notifier inherits all of the attributes from Mojo::EventEmitter and implements the following new ones.
minion
The Minion instance to listen to. Note that this attribute is used to gain access to the "application instance".
transport
An instance of Minion::Notifier::Transport or more likely a subclass thereof. This is used to moderate the communication between processes and even hosts.
METHODS
Minion::Notifier inherits all of the methods from Mojo::EventEmitter and implements the following new ones.
app
A shortcut for $notifier->minion->app
.
emit_event
A low level method used to emit the batch of events related to received minion events.
setup_listener
Setup the linkages that allow for notifications to be received. This is called automatically by Mojolicious::Plugin::Minion::Notifier once the ioloop has started.
setup_worker
Setup the linkages that cause the jobs to send notifications when reaching "finished" or "failed" states. This is called automatically by Mojolicious::Plugin::Minion::Notifier.
FUTURE WORK
Document all included classes (hey this is a preview release!)
Improve backend loader mechanism
Investigate timeout behavior for the various transport backends
SEE ALSO
Mojolicious - Real-time web framework
Minion - The Mojolicious job queue
Mercury - A lightweight message broker using Mojolicious' WebSockets for transport
SOURCE REPOSITORY
http://github.com/jberger/Minion-Notifier
AUTHOR
Joel Berger, <joel.a.berger@gmail.com>
COPYRIGHT AND LICENSE
Copyright (C) 2015 by Joel Berger
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.