2017 © Pedro Peláez
 

package queue-stats

Laravel 5.5 package to collect queue statistics

image

crazybooot/queue-stats

Laravel 5.5 package to collect queue statistics

  • Monday, November 13, 2017
  • by crazybooot
  • Repository
  • 1 Watchers
  • 0 Stars
  • 3 Installations
  • JavaScript
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 13 Open issues
  • 1 Versions
  • 0 % Grown

The README.md

Laravel package for queued job statistics collecting, (*1)

Install

  • Install composer package to your laravel project ``` bash $ composer require crazybooot/queue-stats

* Add service provider to config/app.php ``` php 'providers' => [ ... Crazybooot\QueueStats\Providers\QueueStatsServiceProvider::class, ],
  • Publish migrations ``` bash $ php artisan vendor:publish --provider="Crazybooot\QueueStats\Providers\QueueStatsServiceProvider" --tag="migrations"

* Run migrations ``` bash $ php artisn migrate
  • Use QueueStatsTrait and QueueStatsInterface on jobs models you want to collect statistics ``` php ... use Crazybooot\QueueStats\Traits\QueueStatsTrait; use Crazybooot\QueueStats\Interfaces\QueueStatsInterface;

class ExampleJob implementes QueueStatsInterface, ShouldQueue { use QueueStatsTrait; }, (*2)

* As well you can use extended artisan command to generate job with QueueStatsTrait and QueueStatsInterface. Just add `StatJobMakeCommand` command to the `app/Console/Kernel.php`. `php artisan make:job` would be override by this command.
``` php
    protected $commands = [
        ...
        Crazybooot\QueueStats\Make\StatJobMakeCommand::class
    ];

Using

Get statistics about jobs:, (*3)

``` php ... use Crazybooot\QueueStats\Models\Job;, (*4)

... // get failed jobs Job::failed()->get();, (*5)

// get success jobs Job::success()->get();, (*6)

// get not handled jobs Job::notHandled()->get();, (*7)

// get jobs handled on specified queue Job::queue('default')->get();, (*8)

// get jobs on specified connection Job::connection('redis')->get();, (*9)

// get jobs with specified class Job::class(ExampleJob::class)->get();, (*10)

// get jobs with specified number of attempts Job::attemptsCount(3)->get();, (*11)

// get jobs which has result Job::withResult()->get();, (*12)

// get jobs which have no result Job::withoutResult()->get();, (*13)

// get jobs with specified type Job::type('custom_type')->get();, (*14)

// get jobs without type Job::withoutType()->get();, (*15)


You can get statistics about one job by using getUuid() method on job instance before dispatching job: ``` php ... use Crazybooot\QueueStats\Models\Job; use App\Job\ExampleJob; ... $job = new ExampleJob(); $uuid = $job->getUuid(); ... dispath($job); ... $jobStats = Job::where('uuid', $uuid)->first(); // returns total job atempts waiting on queue duration in seconds $waitingDuration = $jobStats->getAttribute('waiting_duration'); // returns total job atempts handling duration in seconds $handlingDuration = $jobStats->getAttribute('handling_duration); // return job attempts count $attemptsCount = $jobStats->getAttribute('attempts_count');

You can add some job results to statistics passing array of data you want to save $this->saveResult(). Result will be stored in database in json format what allows to query more complex data with Eloquent or Query Builder. ``` php use Crazybooot\QueueStats\Traits\QueueStatsTrait;, (*16)

class ExampleJob implementes ShouldQueue { use QueueStatsTrait;, (*17)

...

public function handle()
{

...

$this->saveResult([
    'some_key' => [
        'some_key' => 'some_payload'
    ]
]);
}

} ```, (*18)

Requirements

  • PHP: 7.0+
  • Laravel: 5.5
  • Supported queue drivers: database, beanstalkd, redis

The Versions

13/11 2017

dev-master

9999999-dev

Laravel 5.5 package to collect queue statistics

  Sources   Download

The Requires

 

by Avatar crazybooot