activecollab / jobsqueuecommands
Active Collab job queue commands
Installs: 38
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 7
Forks: 0
Open Issues: 0
pkg:composer/activecollab/jobsqueuecommands
Requires
- activecollab/containeraccess: ~1.0.0
- activecollab/jobsqueue: dev-next
- symfony/console: ~2.6
Requires (Dev)
- monolog/monolog: ~1.0
- phpunit/phpunit: ~5.0
- pimple/pimple: ~3.0
This package is auto-updated.
Last update: 2025-10-05 03:11:34 UTC
README
This package contains a couple of useful CLI commands that make work with activecollab/jobsqueue easier. Implemented commands are:
- clear_failed_jobs- Clear failed jobs losts
- create_tables- Create job queue tables (in case you are using MySQL queue)
- enqueue-> Add job to the queue
- failed_job_reasons- Find job by type, and return all distinct reasons why it failed in the past
- failed_jobs- List content of failed jobs log
- restore_failed_jobs- Restore failed jobs by type
- run_jobs- Run jobs from the queue
- run_queue_maintenance- Perform queue maintenance (unstuck jobs, remove old logs etc)
Running Jobs
This command is designed to be started and to execute jobs until a particular time limit is reached. This command supports following options:
- --seconds(- -s) - How long should one call be kept alive and execute jobs (default value is 50 seconds),
- --channels(- -c) - Channels that this command should pick jobs up from (default is- mainchannel).
Check this example cron configuration:
*   *   *   *   *   /path/to/my/consumer run_jobs -s 180 -c main,mail
This command starts a consumer instance that listens on mail and mail channels every minute, and it is kept alive for 180 seconds. As a result, we always have three consumer instances running and executing jobs, which means that we can push quite a bit of work through them.
DI Container
All commands expect that you provide them with Interop\Container\ContainerInterface DI container with following elements:
- log- Instance that implements- \Psr\Log\LoggerInterfaceinterface
- dispatcher- Instance that implements- \ActiveCollab\JobsQueue\DispatcherInterfaceinterface (usually- \ActiveCollab\JobsQueue\Dispatcherinstance)
Commands use these instances to perform the work that they need to do and DIC offers a convenient way to inject them.