Download the PHP package bushbaby/slmqueuedoctrine-postponablejobstrategy without Composer
On this page you can find all versions of the php package bushbaby/slmqueuedoctrine-postponablejobstrategy. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download bushbaby/slmqueuedoctrine-postponablejobstrategy
More information about bushbaby/slmqueuedoctrine-postponablejobstrategy
Files in bushbaby/slmqueuedoctrine-postponablejobstrategy
Package slmqueuedoctrine-postponablejobstrategy
Short Description BsbPostponableJobStrategy is a strategy for the SlmQueueDoctrine ZF2 module that provides the ability for jobs to postpone their execution until other jobs have successfully been processed.
License MIT
Homepage https://github.com/bushbaby/BsbPostponableJobStrategy
Informations about the package slmqueuedoctrine-postponablejobstrategy
BsbPostponableJobStrategy
BsbPostponableJobStrategy is a strategy for the SlmQueueDoctrine ZF2 module that provides the ability for jobs to postpone their execution until other jobs have successfully been processed.
Rationale
I needed a simple way to ensure a particular order of job processing. This is not a problem if you have just one worker as those jobs are executed in the order they where added to the queue (FIFO). However when multiple workers process multiple queue's this can't be garanteed anymore.
Installation
BsbPostponableJobStrategy requires Composer. To install it into your project, just add the following line into your composer.json file:
Enable the module by adding BsbPostponableJobStrategy in your application.config.php file.
Configuration
By enabling this module a new strategy is registered into the strategy manager of SlmQueue. You should then enable it by adding it some configuration to the appropiate worker queues. A suggested place is the slm_queue.global.php in your autoload configuration directory.
example: enabled the PostponableJobStrategy for the queue called default with a release delay of 30 seconds
PostponableJobStrategy
The PostponableJobStrategy accepts one option.
release_delay (int) number of seconds used as delay option while releasing the job back into the queue this
Usage
The jobs that need to 'wait' with execution until some other job is done must implement the PostponableJobInterface. I suggest you use the provided PostponableJobTrait.
Then while queueing Jobs you tell your postponable job about jobs that should be processed first:
Known limitation
SlmQueueDoctrine has specific queue options (deleted_lifetime and buried_lifetime) to delete jobs from the database when they have been processed. When this lifetime is immediate (or very short) it (might) becomes impossible to get the status of a processed job. We therefore assume it has been successfully executed and therefore the current job execution is not postponed.