dev-master
9999999-dev https://github.com/ferrumfist/yii-gearmanGearman handler for PHP (fork)
MIT
The Requires
- php >=5.4.0
by Spirin Yaroslav
extension yii
Gearman handler for PHP (fork)
This extension built on this and this and this The goal of the project is opportunity of starting multiple worker processes on one machine. Work only as process(fork). In config you can set count of nodes, look 'Configuration', (*1)
It is recommended that you install the Gearman library through composer. To do so, add the following lines to your composer.json
file., (*2)
{ "require": { "ferrumfist/yii-gearman": "dev-master" } }
'components' => [ 'gearman' => [ 'class' => 'ferrumfist\yii\gearman\GearmanComponent', 'servers' => [ ['host' => '127.0.0.1', 'port' => 4730], ], 'user' => 'www-data', 'jobs' => [ 'syncCalendar' => [ 'class' => 'common\jobs\SyncCalendar', 'count'=>10 // default count 1 ], ... ] ] ], ... 'controllerMap' => [ 'gearman' => [ 'class' => 'ferrumfist\yii\gearman\GearmanController', 'gearmanComponent' => 'gearman', ], ... ],
namespace common\jobs; use ferrumfist\yii-gearman\JobBase; class SyncCalendar extends JobBase { public function execute(\GearmanJob $job = null) { // Do something } }
Yii::app()->gearman->getDispatcher()->background('syncCalendar', new JobWorkload([ 'params' => [ 'data' => 'value' ] ])); // run in background Yii::app()->gearman->getDispatcher()->execute('syncCalendar', new JobWorkload([ 'params' => [ 'data' => 'value' ] ])); // run synchronize
[program:yii-gearman-worker] command=php [path_to_your_app]/yii gearman/start %(process_num)s process_name=gearman-worker-%(process_num)s priority=1 numprocs=5 numprocs_start=1 autorestart=true
Gearman handler for PHP (fork)
MIT
extension yii