pmg / queue-pheanstalk
A pmg/queue driver implementation for Pheanstalk and Beanstalkd
Installs: 53 882
Dependents: 0
Suggesters: 2
Security: 0
Stars: 3
Watchers: 11
Forks: 1
Open Issues: 1
pkg:composer/pmg/queue-pheanstalk
Requires
- php: ^8.3
- pda/pheanstalk: ^4.0
- pmg/queue: ^6.2
Requires (Dev)
- phpunit/phpunit: ^9.6.23
- symfony/phpunit-bridge: ^v6.4.16
- v7.0.0
- v6.0.0
- v5.2.0
- v5.1.0
- v5.1.0-BETA1
- v5.0.0
- v5.0.0-BETA3
- v5.0.0-BETA2
- v5.0.0-BETA1
- v3.0.0
- 3.0.0-RC1
- dev-master / 2.0.x-dev
- 2.0.0
- 1.1.0
- 1.0.0
- dev-ALLI-19969-upgrade-queue-pheanstalk-to-use-symfony-7-4
- dev-ALLI-19933-update-queue-pheanstalk-to-php-8-5
- dev-ALLI-17485-upgrade-pmg-queue-pheanstalk-to-support-php-8-4
- dev-version-2
- dev-version-1
This package is auto-updated.
Last update: 2025-12-08 16:22:27 UTC
README
A driver for pmg/queue backed by Pheanstalk and Beanstalkd.
See the pmg/queue readme for the documentation of how the queue system as a whole works.
See the examples directory for examples of how to glue everything together.
Quick Example
Pheanstalk is a PHP library for interacting
with Beanstalkd. PheanstalkDriver lets you
take advantage of Beanstalkd as a queue backend.
use Pheanstalk\Pheanstalk; use PMG\Queue\DefaultConsumer; use PMG\Queue\Driver\PheanstalkDriver; use PMG\Queue\Serializer\NativeSerializer; use PMG\Queue\Serializer\SigningSerializer; // ... $serilizer = new NativeSerializer('this is the secret key'); $driver = new PheanstalkDriver(new \Pheanstalk\Pheanstalk('localhost'), $serializer, [ // how long easy message has to execute in seconds 'ttr' => 100, // the "priority" of the message. High priority messages are // consumed first. 'priority' => 1024, // The delay between inserting the message and when it // becomes available for consumption 'delay' => 0, // The ttr for retries jobs 'retry-ttr' => 100, // the priority for retried jobs 'retry-priority' => 1024, // When jobs fail, they are "burieds" in beanstalkd with this priority 'fail-priority' => 1024, // A call to `dequeue` blocks for this number of seconds. A zero or // falsy value will block until a job becomes available 'reserve-timeout' => 10, ]); // $handler instanceof PMG\Queue\MessageHandler $consumer = new DefaultConsumer($driver, $handler);
Dealing with Failed Messages
By default, PheanstalkDriver will bury
any message passed to PheanstalkDriver::fail. This is, generally, a good thing
if there are no other accountability measures around your queue system.
That said, pmg/queue does nothing for you regarding kicking jobs back to a
ready state. If there are other accountability measures around your queue
implementation and you'd rather just delete failed messages after they've been
retried, use a different FailureStrategy.
use Pheanstalk\Pheanstalk; use PMG\Queue\DefaultConsumer; use PMG\Queue\Driver\PheanstalkDriver; use PMG\Queue\Driver\Pheanstalk\DeleteFailureStrategy; use PMG\Queue\Serializer\NativeSerializer; // ... $serilizer = new NativeSerializer('this is the secret key'); $failureStrategy = new DeleteFailureStrategy(); $driver = new PheanstalkDriver(new \Pheanstalk\Pheanstalk('localhost'), $serializer, [ // as above ], $failureStrategy); // $handler instanceof PMG\Queue\MessageHandler $consumer = new DefaultConsumer($driver, $handler);
Feel free to implement PMG\Queue\Driver\Pheanstalk\FailureStrategy if a
different solution is needed.