Skip to content

PHP Class to handle concurrent running Jobs to utilize the power of multiple cores

License

Notifications You must be signed in to change notification settings

jesusch/php-queue

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

php-queue

PHP Class to handle concurrent running Jobs to utilize the power of multiple cores

Background

After some search I was not able to find a php-queue alike class. This code was inspired by php-resque

Requirements

  • PHP 5.3+
  • php-pctnl
  • Composer

Getting Started

The easiest way to work with php-queue is when it's installed as a Composer package inside your project. Composer isn't strictly required, but makes life a lot easier.

If you're not familiar with Composer, please see https://getcomposer.org/.

  1. Add php-queue to your application's composer.json.
{
    // ...
    "require": {
        "jesusch/php-queue": "*"  
    },
    // ...
}
  1. Run composer install.

  2. If you haven't already, add the Composer autoload to your project's initialization file. (example)

require 'vendor/autoload.php';

Jobs

Queueing Jobs

Jobs are queued as follows:

$queue = new \JobQueue\Queue();
$queue->setMaxProcs(10);

$job = new \JobQueue\Job();

$queue->appendJob($job);

$queue->waitForJobs();

Defining Jobs

Each job should be in its own class, must extend \JobQueue\AbstractJob and include a public run method.

class My_Job extends \JobQueue\AbstractJob
{
    public function run()
    {
        
        // Work work work
        echo 'some fancy job';
        $sleep = rand(1,5);
        sleep($sleep);
    }
}

About

PHP Class to handle concurrent running Jobs to utilize the power of multiple cores

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages