visual-craft / beanstalk-scheduler
Background jobs scheduling using Beanstalk
Installs: 14 875
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: >=5.5.0
- pda/pheanstalk: v3.0.0
- psr/log: 1.0.*@dev|~1.0
This package is auto-updated.
Last update: 2025-03-20 21:05:57 UTC
README
Background jobs scheduling using Beanstalk
Install
$ composer require visual-craft/beanstalk-scheduler
Usage
// Create Beanstalkd connection
$connection = new \Pheanstalk\Pheanstalk('127.0.0.1');
// Add job
$manager = new \VisualCraft\BeanstalkScheduler\Manager($connection, 'some_queue');
$job = new \VisualCraft\BeanstalkScheduler\Job('some data');
$manager->submit($job);
// or
//$manager->submit($job, 60); // with the delay of 60 seconds
// Define worker
class SomeWorker implements \VisualCraft\BeanstalkScheduler\WorkerInterface
{
public function work(Job $job)
{
// do some work
// $job->getPayload() returns 'some data'
// you can reschedule failed job:
// throw new \VisualCraft\BeanstalkScheduler\Exception\RescheduleJobException();
}
public function isReschedulableException(\Exception $exception)
{
// Another way of rescheduling failed job
// Put some logic here
return true;
}
public function fail(Job $job)
{
// Optionally you can do something with failed job
}
}
// Process job
$scheduler = new \VisualCraft\BeanstalkScheduler\Scheduler($connection, 'some_queue');
$scheduler
->setWorker(new SomeWorker())
// Define rescheduling configuration:
->setReschedule([20, 30])
;
$scheduler->process();
License
This code is released under the MIT license. See the complete license in the file: LICENSE