2017 © Pedro Peláez
 

library laravel-queue-manager

Laravel Queue Manager

image

pierophp/laravel-queue-manager

Laravel Queue Manager

  • Friday, June 1, 2018
  • by pierophp
  • Repository
  • 2 Watchers
  • 5 Stars
  • 898 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 38 Versions
  • 10 % Grown

The README.md

Laravel Queue Manager

The Laravel Queue Manager, manage the queue process worker., (*1)

It uses Supervisor as Process Control System., (*2)

It also has a scheduler system built-in., (*3)

Installation

Composer

$ composer require pierophp/laravel-queue-manager

Publish

$ php artisan vendor:publish --provider="LaravelQueueManager\Providers\LaravelQueueManagerServiceProvider"

Running the migration

If you have MySQL version before 5.7, change in the migration the field "schedule_config" from "json" to "text"., (*4)

$ php artisan migrate

Adding the provider

You need to add the provider at the file config/app.php, (*5)

LaravelQueueManager\Providers\LaravelQueueManagerServiceProvider::class,

Configuration

Generating a job

You need generate a class that extends LaravelQueueManager\AbstractJob., (*6)

It's necessary to implement 2 methods:, (*7)

Method Description
getName() The name of the job
execute() The code of the job yourself

Dispatching a new job

You need create a new instance of your job and call the dispatch() method., (*8)

Or use the CLI:, (*9)

$ php artisan queue-manager:generate-queue queue_name

You can set optional params too:, (*10)

$ php artisan queue-manager:generate-queue queue_name foo=test,bar=test

Database

To the job work correctly, it is necessary generate a row in the queue_config table., (*11)

Field Description
name It's the same of the return of the getName() method.
class_name The full path with namespace of your job class (\App\Jobs\TestJob)
active If the job is active or not
schedulable If the job is schedulable or not
schedule_config A JSON config of the schedule. {"method" : "The schedule methods from laravel", "params": "The params to the schedule method (optional)", "props": [ { "my_job_prop": 1 }, { "my_job_prop": 2 } ]}
max_attemps The max attempts of the queue
max_instances The max parallel instances of the queue
timeout The timeout of the queue
delay The delay to the next execution (Not implemented yet)
connection The connection name of the queue provider. (If null = default)
aggregator The aggregator is used to group the queues in a report
config The config is used to configure a dynamic functionality. Example json below
Config field example
{
  "nextQueues":{
    "onError":[
      {
        "url":"url/test",
        "data":{
          "param":value
        },
        "name":"QUEUE_NAME",
        "method":"POST",
        "service":"SERVICE",
        "delay_seconds":1
      },
      {
        "url":"url/test",
        "data":{
          "param":value
        },
        "name":"QUEUE_NAME",
        "method":"GET",
        "service":"SERVICE",
        "delay_seconds":1
      }
    ],
    "onSuccess":[
      {
        "url":"url/test",
        "data":{
          "param":value
        },
        "name":"QUEUE_NAME",
        "method":"POST",
        "service":"SERVICE",
        "delay_seconds":1
      }
    ]
  }
}

Config

At the queue_manager.php config file you can configure:, (*12)

Field Description Default
artisan_path The artisan path base_path('artisan')
log_path The log path storage_path('logs/worker.log')
supervisor_config_file The supervisor config file /etc/supervisor/conf.d/laravel-queue.conf
supervisor_bin The supervisor bin path /usr/bin/supervisorctl
supervisor_user The supervisor user docker
supervisor_update_timeout The supervisor update timeout to gracefully stop the process when a configuration change 600
execute_as_api Enable the queue as API mode false
api_url URL to run the queue as API mode http://127.0.0.1/queue/process
fallback_connections Array of fallback connections when first provider fails to dispatch []

Showing all available jobs

$ php artisan queue-manager:show-jobs

Getting error events

You need add to your AppServiceProvider and log as you like:, (*13)

$this->app['events']->listen(\LaravelQueueManager\Events\ScheduleError::class, function(\LaravelQueueManager\Events\ScheduleError $error){
    // my code
});

$this->app['events']->listen(\LaravelQueueManager\Events\DispatchQueueError::class, function(\LaravelQueueManager\Events\DispatchQueueError $error){
    // my code
});

Deploying

Supervisor config

You need configure a cron to run as root every minute to generate the supervisor config, (*14)

$ php artisan queue-manager:generate-config

Scheduler

You need configure a cron to run every minute to generate the scheduler, (*15)

$ php artisan schedule:run

Queue Restart

Every time you change the PHP code, it's necessary to restart the queues. Put this at your deploy script., (*16)

$ php artisan queue:restart

API Mode

Introduction

To easily scale your jobs machine, you can run the queues in API mode. An API is much more easy to apply auto-scale., (*17)

Configuration

In your route configuration file add:, (*18)

$api->post('queue/process', 'LaravelQueueManager\Http\Controllers\QueueController@process');

Edit in your "queue_manager.php" config file the execute_as_api and api_url options., (*19)

The Versions

01/06 2018

dev-master

9999999-dev

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

01/06 2018

v0.0.37

0.0.37.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

01/06 2018

v0.0.36

0.0.36.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

21/05 2018

v0.0.35

0.0.35.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

07/05 2018

v0.0.32

0.0.32.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

07/05 2018

v0.0.33

0.0.33.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

07/05 2018

v0.0.34

0.0.34.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

11/04 2018

v0.0.31

0.0.31.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

28/03 2018

v0.0.30

0.0.30.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

28/03 2018

v0.0.29

0.0.29.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

27/03 2018

v0.0.28

0.0.28.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

27/03 2018

v0.0.27

0.0.27.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

26/03 2018

v0.0.25

0.0.25.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

23/03 2018

v0.0.24

0.0.24.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

23/03 2018

v0.0.23

0.0.23.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

02/03 2018

v0.0.22

0.0.22.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

02/03 2018

v0.0.21

0.0.21.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

17/04 2017

v0.0.20

0.0.20.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

12/04 2017

v0.0.19

0.0.19.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

31/03 2017

v0.0.18

0.0.18.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

21/03 2017

v0.0.17

0.0.17.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

21/03 2017

v0.0.16

0.0.16.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

20/03 2017

v0.0.15

0.0.15.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

20/03 2017

v0.0.14

0.0.14.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

17/03 2017

v0.0.13

0.0.13.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

17/03 2017

v0.0.12

0.0.12.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

17/03 2017

v0.0.11

0.0.11.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

27/01 2017

v0.0.10

0.0.10.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

27/01 2017

dev-laravel54

dev-laravel54

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

25/01 2017

v0.0.9

0.0.9.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

08/12 2016

v0.0.8

0.0.8.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

08/12 2016

v0.0.7

0.0.7.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

11/11 2016

v0.0.6

0.0.6.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

07/11 2016

v0.0.5

0.0.5.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

27/10 2016

v0.0.4

0.0.4.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

27/10 2016

v0.0.3

0.0.3.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

27/10 2016

v0.0.2

0.0.2.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager

21/10 2016

v0.0.1

0.0.1.0

Laravel Queue Manager

  Sources   Download

MIT

The Requires

 

by Piero Giusti
by Kleber Nascimento

laravel queue supervisor queue-manager