evilnet / queue-jobs-bundle
Simple queue system like in Laravel for Symfony
Installs: 81
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=5.6
- predis/predis: ^1.1
- symfony/event-dispatcher: ^3.4
This package is auto-updated.
Last update: 2024-12-29 05:32:55 UTC
README
Jobs system like in Laravel now in Symfony 3.x!
About
Are you tired of fancy rabbitmq configurations? Would you like such a simplicity of work as in Laravel? That's what this package is for! I created it for the ecommerce project to process simple tasks, but it may also be useful to you
Install
composer require evilnet/queue-jobs-bundle
Post-Install
Enable package in your AppKernel.php
$bundles = [
new Evilnet\QueueJobsBundle\QueueJobsBundle(),
];
And add these parameters to your parameters.yml
queue_redis_ip: 127.0.0.1 (usually)
queue_redis_port: 6379 (usually)
default_queue_name: default
And that's it! You can test it by running two commands in terminal
bin/console worker:start default
And then demo dispatcher
bin/console dispatch:test
You should see Hello World in terminal with worker
Example code
Example Job Class
<?php
namespace Evilnet\QueueJobsBundle\ExampleJob;
use Evilnet\QueueJobsBundle\Dispatcher\DispatchableInterface;
class HelloWorld implements DispatchableInterface
{
public $test_value;
public function __construct()
{
$this->test_value = 'Hello from queue!';
}
public function execute(): bool
{
echo $this->test_value."\n";
return true;
}
}
Example of dispatch job
<?php
namespace Evilnet\QueueJobsBundle\Command;
use Evilnet\QueueJobsBundle\Dispatcher\DispatcherInterface;
use Evilnet\QueueJobsBundle\ExampleJob\HelloWorld;
class ExampleService
{
protected $dispatcher;
public function __construct(DispatcherInterface $dispatcher)
{
$this->dispatcher = $dispatcher;
}
public function test()
{
$hello_world_job = new HelloWorld();
$this->dispatcher->dispatch($hello_world_job, 'default'); //Queue name. You can use configured parameter here
}
}
And to be honest... That's all!
TODO BY PRIORITY
- Tests
- Better configuration for Bundle where you can choose adapter etc.
- Timeout for jobs. Execute after 15 minutes etc.
- More adapters. For now only redis is available
Tests
Coming soon!
License
This project is licensed under the MIT License - see the LICENSE.md file for details