Forked from shakura/yii2-gearman.
It is recommended that you install the Gearman library through composer. To do so, add the following lines to your composer.json
file.
{
"require": {
"thmrxx/yii2-gearman": "dev-master"
}
}
'components' => [
'gearman' => [
'class' => 'thmrxx\yii2\gearman\GearmanComponent',
'servers' => [
['host' => '127.0.0.1', 'port' => 4730],
],
'user' => 'www-data',
// 'timeout' => 30000,
'jobs' => [
'syncCalendar' => [
'class' => 'common\jobs\SyncCalendar'
],
...
]
]
],
...
'controllerMap' => [
'gearman' => [
'class' => 'thmrxx\yii2\gearman\GearmanController',
'gearmanComponent' => 'gearman'
],
...
],
namespace common\jobs;
use thmrxx\yii2\gearman\JobBase;
class SyncCalendar extends JobBase
{
public function execute(\GearmanJob $job = null)
{
// Do something
}
}
yii gearman/start 1 // start the worker with unique id
yii gearman/restart 1 // restart worker
yii gearman/stop 1 // stop worker
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
Yii::$app->gearman->setTimeout(10000)->getDispatcher()->execute('syncCalendar', new JobWorkload([
'params' => [
'data' => 'value'
]
])); // set timeout in milliseconds
Example of Supervisor config to manage multiple workers
[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