PHP Gearman Task有时会返回空对象

时间:2012-01-12 20:58:58

标签: php gearman

我有一个简单的Gearman客户端和工作人员。我在我的Ubuntu桌面上运行。我已经安装了gearman-beta pecl软件包和来自synaptic的Gearman版本。

我的问题是有时我从工人那里得到一个空对象。大约50%的时间它显示预期的文本,其余的时间显示“GearmanTask对象” ( )“(来自我在客户端的print_r)

在任何情况下都不会发生异常,客户端始终认为工作人员已成功完成。我还应该注意,没有任何超时,客户端脚本可以快速执行。

客户端

$gmclient = new GearmanClient();
$gmclient->addServer();

$gmclient->addTask('test','just some text');
$gmclient->setCompleteCallback("complete");
$gmclient->setFailCallback('fail');
$gmclient->runTasks(); 

function fail() {
  echo "FAIL";
}
function complete($task) { 
  print "COMPLETE: " . $task->data() . "<br />";
  if($task->data() == '') {
     echo '<pre>'.print_r($task, true).'</pre><br />';
     echo $task->error(); 
  }
}

工人(test.php)

$worker = new GearmanWorker();
$worker->addServer();
$worker->addFunction("test", "test_function");
while (true) {
  $worker->work();
  print $worker->returnCode();
}
function test_function($job) {
  return $job->workload() . ' worked!';
}

我在/ var / log / gearman-job-server中没有任何内容。

思想?

1 个答案:

答案 0 :(得分:0)

这可能看起来很奇怪,但以下对我有用。

您应该替换以下块

$gmclient = new GearmanClient();
$gmclient->addServer();

$gmclient->addTask('test','just some text');
$gmclient->setCompleteCallback("complete");
$gmclient->setFailCallback('fail');
$gmclient->runTasks();

用这个

$gmclient = new GearmanClient();
$gmclient->addServer();

$gmclient->setCompleteCallback("complete");
$gmclient->setFailCallback('fail');

$gmclient->addTask('test','just some text');
$gmclient->runTasks();