micmorozov/yii2-gearman

PHP的Gearman处理器(分支版本)

安装次数: 5,805

依赖关系: 0

建议者: 0

安全性: 0

星级: 1

关注者: 1

分支: 29

类型:yii2-extension

dev-master 2018-04-10 07:35 UTC

This package is auto-updated.

Last update: 2024-09-24 12:05:17 UTC


README

本扩展基于以下项目构建:[这个](https://github.com/Filsh/yii2-gearman)、[这个](https://github.com/sinergi/gearman) 和 [这个](https://github.com/shakura/yii2-gearman)。项目目标是允许在一台机器上启动多个工作进程。仅作为进程(分支)工作。在配置中您可以设置节点数量,请参阅'配置'部分。

安装

建议您通过composer安装Gearman库。如何通过composer安装。为此,请将以下行添加到您的composer.json文件中。

{
    "require": {
       "micmorozov/yii2-gearman": "dev-master"
    }
}

配置

'components' => [
  'gearman' => [
      'class' => 'micmorozov\yii2\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' => 'micmorozov\yii2\gearman\GearmanController',
        'gearmanComponent' => 'gearman',
    ],
    ...
],

作业示例

namespace common\jobs;

use micmorozov\yii2-gearman\JobBase;

class SyncCalendar extends JobBase
{
    public function execute(\GearmanJob $job = null)
    {
        // Do something
    }
}

管理工作进程

yii gearman/start  // start the worker
yii gearman/restart  // restart worker
yii gearman/stop // stop worker

使用Dispatcher的示例

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

管理多个工作进程的Supervisor配置示例

[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