Skip to content

Latest commit

 

History

History
309 lines (212 loc) · 10 KB

transport.md

File metadata and controls

309 lines (212 loc) · 10 KB

Transport

Introduction

Transports are the foundations behind the storage of tasks: once tasks are defined in the configuration or scheduled via the Scheduler, every task is stored via transports.

Think of transports like the transports used by the following components in Symfony:

This bundle defines a set of transports, each transport has its own configuration and can be overridden if required.

List of available transports

Informations

Once created, the transport is injected into the Scheduler, you will probably never need to interact with it without using the Scheduler, otherwise, the transport is injected using the TransportInterface and the scheduler.transport identifier.

<?php

declare(strict_types=1);

use SchedulerBundle\Transport\TransportInterface;
use Symfony\Component\HttpFoundation\Request;

final class FooController
{
    public function __invoke(Request $request, TransportInterface $transport)
    {
        // ...
    }
}

Note: Using the transport without the scheduler can lead to edge issues as the scheduler is synchronized with it.

Configuration

Every transport has its own configuration keys (thanks to query parameters), here's the default keys:

  • execution_mode: Define the schedule policy used by the transports (more info on Policies).
  • path: Define the path used by the FilesystemTransport.

InMemory

The InMemoryTransport stores every task in memory, this transport is perfect for test environnement or/and for POC applications.

Usage

scheduler_bundle:
    transport:
        dsn: 'memory://first_in_first_out'

Configuration: This transport requires that you provide an execution_mode as the first parameter, this value is used to sort every new task and improve performances/resources consumption.

Filesystem

The FilesystemTransport stores every task in files, the default path is %kernel.project_dir%/var/tasks.

Usage

scheduler_bundle:
    transport:
        dsn: 'filesystem://first_in_first_out' # OR 'fs://first_in_first_out' OR 'file://first_in_first_out'

Configuration:

  • This transport requires that you provide an execution_mode as the first parameter, this value is used to sort every new task and improve performances/resources consumption.

  • The second and optional key is the path where every task is stored (using json format):

scheduler_bundle:
    transport:
        dsn: 'filesystem://first_in_first_out?path=/srv/app'
  • The third and optional key is the filename_mask which define the "mask" of every task file (default to %s/_symfony_scheduler_/%s.json):
scheduler_bundle:
    transport:
        dsn: 'filesystem://first_in_first_out?filename_mask=%s/_foo/%s.json'

Important: This configuration key must use the json file extension, the mask is used in combination with the path configuration key to store every task.

Note: Container parameters cannot be passed here as the container is not involved in the transport configuration.

Note: Keep in mind that this directory could be versioned if required

Cache

Introduced in 0.4

The CacheTransport stores every task in a PSR compliant CacheItemPoolInterface, every cache adapter that implement this interface can be used.

By default, this bundle use the ones defined in the cache configuration key of the framework:

framework:
    cache:
        app: cache.adapter.filesystem

Usage

scheduler_bundle:
    transport:
        dsn: 'cache://app'

Configuration: This transport requires that you provide the name of the pool to use, the execution_mode option is allowed.

FailOver

The FailOverTransport allows to use multiple transports and "prevent" errors when trying to schedule a task, this approach is also known as "High-Availability", it is particularly useful if you use a transport that can fail during an operation (like network-related, etc).

Usage

scheduler_bundle:
    transport:
        dsn: 'failover://(memory://first_in_first_out || memory://last_in_first_out)' # Or 'fo://(memory://first_in_first_out || memory://last_in_first_out)'

configuration: This transport requires at least 2 transports to be used (each one can be configured as usual).

LongTail

The LongTail allows to use multiple transports. It's specifically designed to maximize the transport usage by always trying to use the transport with the lowest amount of tasks. This approach can help when you're scheduling tasks in a high-stress environment.

Usage

scheduler_bundle:
    transport:
        dsn: 'longtail://(memory://first_in_first_out <> memory://last_in_first_out)' # Or 'lt://(memory://first_in_first_out <> memory://last_in_first_out)'

configuration: This transport requires at least 2 transports to be used (each one can be configured as usual).

RoundRobin

The RoundRobin allows using multiple transports, the main advantages of this transport is to distribute the work load around multiple transports, think of it as a "load-balancer" transport.

Usage

scheduler_bundle:
    transport:
        dsn: 'roundrobin://(memory://first_in_first_out && memory://last_in_first_out)' # Or 'rr://(memory://first_in_first_out && memory://last_in_first_out)'

Configuration:

  • This transport requires at least 2 transports to be used (each one can be configured as usual).
  • A quantum can be defined to determine the maximum duration (expressed in seconds) within a transport MUST perform the action, the default value is 2.

Note: By default, the execution duration limit is based around the formula: count(transports) * quantum.

Lazy

The LazyTransport allows to perform actions using an asynchronous approach.

Usage

scheduler_bundle:
    transport:
        dsn: 'lazy://(memory://batch)'

Fiber

Introduced in 0.9

The FiberTransport allows performing actions using native fibers.

Usage

scheduler_bundle:
    transport:
        dsn: 'fiber://(memory://batch)'

Redis

The RedisTransport allows to use Redis as tasks storage, this transport is useful if you need to share tasks between multiple projects/instances.

Requirements: The Redis transport requires at least redis >= 4.3.

Usage

scheduler_bundle:
    transport:
        dsn: 'redis://user:password@host:port'

configuration: This transport requires multiple options:

  • The user of the Redis instance
  • The related password
  • The host of the Redis instance
  • The optional port of the Redis instance

Extra configuration

This transport can be configured using multiple options:

  • execution_mode: Relates to default configuration keys.
  • list: Define the name of the list that store tasks.
scheduler_bundle:
    transport:
        dsn: 'redis://user:[email protected]:6543?execution_mode=first_in_first_out&list=foo'

Doctrine

The DoctrineTransport allows to use Doctrine connections as tasks storage. This transport is useful if you need to share tasks between multiple projects/instances.

Usage

scheduler_bundle:
    transport:
        dsn: 'doctrine://default?execution_mode=first_in_first_out' # Or 'dbal://default?execution_mode=first_in_first_out'

Configuration: This transports requires the following configuration keys:

  • The connection name as the "host"
  • The optional table_name where the tasks must be stored (default to _symfony_scheduler_tasks)
  • The optional auto_setup to define if the connection should configure the table if it does not exist

Extra configuration

This transport can configure multiple options:

  • execution_mode: Relates to default configuration keys.
scheduler_bundle:
    transport:
        dsn: 'doctrine://default?execution_mode=first_in_first_out&table_name=foo&auto_setup=false'

Extra integration

The Doctrine bride integrate deeply with the Doctrine bundle, the first integration is done via the connection which is retrieved via the doctrine service, the second integration is done via DoctrineMigrationsBundle, thanks to this one and when using bin/console doctrine:migrations:diff, the schema related to the task list can be generated.

Note: An important thing to keep in mind is that if you don't use the DoctrineMigrationsBundle bundle and the auto_setup option is set to true, the schema is generated when scheduling the tasks.

Creating a custom transport

If desired, you can create your own transport thanks to TransportInterface, it requires that you create your own transport factory via TransportFactoryInterface.

Once created, both classes will be autoconfigured and autowired into the related classes.