PHP Gearman重复任务

时间:2013-01-27 00:04:59

标签: php task-queue gearman worker

我得到了:

  • Debian 6
  • nginx 1.2.6
  • PHP 5.3.20-1~docdeb.0(fpm-fcgi)(建于2012年12月24日11:53:16)
  • gearmand 1.1.4
  • pecl gearman ext 1.1.1

我有两个脚本(可能是我从php复制它们)。客户端:

<?php
$gmc= new GearmanClient();
$gmc->addServer();

$gmc->setCompleteCallback("reverse_complete");
$gmc->setStatusCallback("reverse_status");

$gmc->addTask("reverse", "!dlroW olleH", null, "2");

if (!$gmc->runTasks())
{
    echo "Error " . $gmc->error() . "\n";
    exit;
}

echo "Done\n";

function reverse_status($task)
{
    echo "Status: " . $task->unique() . ", " . $task->jobHandle() . " - " . $task->taskNumerator() .
         "/" . $task->taskDenominator() . "\n";
}

function reverse_complete($task)
{
    echo "Done: " . $task->unique() . ", " . $task->data() . "\n";
}

?>

和工人:

<?php
$gmworker= new GearmanWorker();
$gmworker->addServer('127.0.0.1');
$gmworker->addOptions(GEARMAN_WORKER_GRAB_UNIQ);
$gmworker->addFunction("reverse", "reverse_fn");

print "Waiting for tasks...\n";
while($gmworker->work())
{

  if ($gmworker->returnCode() != GEARMAN_SUCCESS)
  {
    echo "return code: " . $gmworker->returnCode() . "\n";
    break;
  }
}

function reverse_fn($job)
{

  echo "uniq: " . $job->unique() . "\n";
  echo "I got job: " . $job->handle() . "\n";

  $workload = $job->workload();
  $workload_size = $job->workloadSize();

  echo "Workload: $workload ($workload_size)\n";

  for ($x= 0; $x < $workload_size; $x++)
  {
    echo "Sending status: " . ($x + 1) . "/$workload_size is done\n";
    $job->sendStatus($x+1, $workload_size);
    $job->sendData(substr($workload, $x, 1));
    sleep(1);
  }

  $result= strrev($workload);
  echo "The result: $result\n";

  return $result;
}

?>

我通过&#34; gearmand -d&#34;运行gearmand。 我通过&#34; php worker.php&#34;。

开始工作

我从浏览器打开我的客户端脚本,任务进入服务器,一切正常。 但是,当我从2个以上的浏览器标签打开相同的脚本时,gearmand会收到2个具有相同唯一ID的类似任务。

当我添加后台任务或使用doBackground方法或在CLI模式下,这不会发生。 这也不会发生在2个以上不同的浏览器中。

我尝试了不同的客户端和服务器版本。同样的事情发生了。

我完全卡住了。 谢谢你的帮助。

2 个答案:

答案 0 :(得分:0)

$ gmc-&gt; addTask(“reverse”,“!dlroW olleH”,null,“2”);最后一个选项是您的唯一键。所以当然它总是一样的。

答案 1 :(得分:0)

老了,但我想我想出来了。浏览器不允许一次发送2个以上相同的查询。第二个等待第一个先完成。