2017 © Pedro Peláez
 

magento-module magento-jobqueue

JobQueue for Magento using DJJob

image

jkowens/magento-jobqueue

JobQueue for Magento using DJJob

  • Thursday, February 15, 2018
  • by jkowens
  • Repository
  • 10 Watchers
  • 52 Stars
  • 5,562 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 22 Forks
  • 2 Open issues
  • 3 Versions
  • 55 % Grown

The README.md

JobQueue

JobQueue allows Magento applications to place tasks in a queue to be processed asynchronously. It is built on DJJob and makes use of the existing MySQL backend. Some tasks this may be ideal for are:, (*1)

  • Downloading files
  • Processing batch jobs
  • Sending data to a back-office application or third party systems

System Requirements

  • PHP 5.1 or higher
  • MySQL 4.1.20 or higher
  • Magento CE1.6.0-1.9.x/EE1.7.0-1.14.x

Usage

Jobs must extend Jowens_JobQueue_Model_Job_Abstract and implement the perform() method., (*2)

class Foo_Bar_Model_Order_Job extends Jowens_JobQueue_Model_Job_Abstract
{
  public function perform() {
    // implementation logic
  }
}

That job can then be used like so:, (*3)

$job = Mage::getModel('bar/order_job');
$job->setName('Order# 12345')
    ->enqueue();

Name is used to identify the job in backend, so be descriptive! The enqueue method can take two optional parameters, a string for queue name and timestamp to specify a time to run the job., (*4)

The job can also be attempted immediately. If it fails it is added to the default queue for retry., (*5)

$job = Mage::getModel('bar/order_job');
$job->setName('Order# 12345')
    ->performImmediate();

To put the job on a queue other than the default one, performImmediate takes an optional string value for the name of the retry queue., (*6)

Running Jobs

JobQueue requires Magento cron to be configured in order to run pending jobs. By default a JobQueue worker executes the pending jobs every 5 minutes. If a job fails it will be retried up to 10 times. Both of these settings can be configured in the admin panel under System > Configuration > General > JobQueue., (*7)

Jobs in other queues can be executed by adding more cron entries to a custom module config.xml., (*8)

<crontab>
    <jobs>
        <jobqueue_orders>
          <schedule>
            <config_path>jobqueue/config/cron_expr</config_path>
          </schedule>
          <run>
            <model>jobqueue/worker::executeJobs</model>
          </run>
          <queue>orders</queue>
        </jobqueue_orders>
    </jobs>
</crontab>

Alternatively workers could be configured to run as they normally would using DJJob. See the documentation., (*9)

Monitoring Jobs

Pending and failed jobs can be monitored in the admin panel by going to System > JobQueue., (*10)

The Versions

15/02 2018

dev-master

9999999-dev

JobQueue for Magento using DJJob

  Sources   Download

MIT

The Requires

 

15/02 2018

0.6.0

0.6.0.0

JobQueue for Magento using DJJob

  Sources   Download

MIT

The Requires

 

12/03 2016

0.5.0

0.5.0.0

JobQueue for Magento using DJJob

  Sources   Download

MIT

The Requires