Skip to content

Latest commit

 

History

History
74 lines (49 loc) · 2.76 KB

File metadata and controls

74 lines (49 loc) · 2.76 KB

Doctrine Delay Queue Driver Bundle

A driver for Queue Manager Bundle that uses Doctrine to store delayed jobs

This driver doesn't run jobs, it requires another driver to actually process jobs.

It currently only works with MySQL as a native query is required to find jobs in a concurrency safe way.

Latest Stable Version License Build Status

Usage

You should run the daemon for delay in addition to any other daemons you are using. This runner simply moves jobs from Doctrine into your other job queues. Because its not doing much work generally a single instance can cope with a high number of jobs.

./bin/console mcfedr:queue:{name}-runner

Where {name} is what you used in the config. Add -v or more to get detailed logs.

Install

Composer

composer require mcfedr/doctrine-delay-queue-driver-bundle

AppKernel

Include the bundle in your AppKernel

public function registerBundles()
{
    $bundles = [
        ...
        new Mcfedr\QueueManagerBundle\McfedrQueueManagerBundle(),
        new Mcfedr\DoctrineDelayQueueDriverBundle\McfedrDoctrineDelayQueueDriverBundle(),

Config

With this bundle installed you can setup your queue manager config similar to this:

mcfedr_queue_manager:
    managers:
        delay:
            driver: doctrine_delay
            options:
                entity_manager: default
                default_manager: default
                default_manager_options: []

This will create a QueueManager service named "mcfedr_queue_manager.delay"

  • entity_manager - Doctrine entity manager to use
  • default_manager - Default job processor
  • default_manager_options - Default options to pass to job processor put

Options to QueueManager::put

  • time - A \DateTime object of when to schedule this job
  • delay - Number of seconds from now to schedule this job
  • manager - Use a different job processor for this job
  • manager_options - Options to pass to the processors put method

Note

If delay or time option is less then 30 seconds the job will be scheduled for immediate execution

Tables

After you have installed you will need to do a schema update so that the table of delayed tasks is created