我有一个简单的Gearman客户和工人。我在我的ubuntu桌面上运行两者。我已经安装了gearman beta-pecl包和synaptic的gearman版本。
我的问题是有时我从工人那里得到一个空的东西。大约50%的时间显示预期的文本,其余时间显示“gearmantask对象”
(
)“(摘自我在客户处的打印件)
在任何情况下都不会发生异常,客户机始终认为工作进程已成功完成。我还应该注意,没有任何超时,客户端脚本执行得很快。
顾客
$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作业服务器中没有任何内容。
思想?
最佳答案
这可能看起来很奇怪,但下面这句话对我有用。
你应该替换下面的块
$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();
关于php - PHP Gearman Task有时返回空对象,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8842193/