neuron-php / jobs
Job scheduler and runner.
Installs: 186
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/neuron-php/jobs
Requires
- ext-curl: *
- ext-json: *
- dragonmantank/cron-expression: ^3.4
- neuron-php/cli: 0.1.*
Requires (Dev)
- phpunit/phpunit: 9.*
This package is auto-updated.
Last update: 2025-10-13 16:05:48 UTC
README
Neuron-PHP Job Scheduler
Overview
Installation
composer require neuron-php/jobs
Configure the application to use psr-4 autoloading in composer.json as the application relies on the autoloader to create the job objects.
Composer snippet:
"autoload": { "psr-4": { "App\\": "src/" }
Configuration
Example Directory Structure
├── composer.json
├── config
│   ├── config.yaml
│   └── schedule.yaml 
├── src  
│   └── Jobs
│       └── MyJob.php
└── vendor 
Application
The application configuration is loaded from config/config.yaml
Example config.yaml:
logging: destination: \Neuron\Log\Destination\StdOut format: \Neuron\Log\Format\PlainText level: debug system: timezone: US/Eastern base_path: /path/to/app
Schedule
The job schedule is loaded from config/schedule.yaml
Example schedule.yaml:
schedule: testJobWithArgs: class: App\Jobs\ImportData cron: "5 * * * *" args: doSomething: true dontDoSomething: false testJobWithOutArgs: class: App\Jobs\SendReminderEmail cron: "15 * * * *"
- class: The class to instantiate and run.
- cron: The cron expression for the job schedule.
- args: An array of arguments to pass to the job.
Job Classes
Job classes must implement the Neuron\Jobs\IJob interface.
Example Job class:
namespace App\Jobs; use Neuron\Jobs\IJob; use Neuron\Log\Log; class ExampleJob implements IJob { public function getName() : string { return 'TestJob'; } public function run( array $Argv = [] ) : mixed { Log::debug( "TestJob::run( {$Argv['parameterName']} )" ); return true; } }
Running the Scheduler
Infinite Polling
./vendor/bin/neuron jobs:schedule
This will run the scheduler in an infinite polling loop, polling every 60 seconds by default.
The polling interval seconds can be changed with the --interval option.
./vendor/bin/neuron jobs:schedule --interval 5
Single Poll
The scheduler can also be run to perform a single poll of the schedule by using the --poll option.
For best results, the schedule should be run with the --poll option in a cron job and ran once per minute.
./vendor/bin/neuron jobs:schedule --poll
More Information
You can read more about the Neuron components at neuronphp.com