Skip to content

A bundle for running symfony background tasks with doctrine as the driver

License

Notifications You must be signed in to change notification settings

mcfedr/doctrine-delay-queue-driver-bundle

Repository files navigation

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

About

A bundle for running symfony background tasks with doctrine as the driver

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages