其實入門及介紹不想多說舀患,安裝這一塊也不想多說,單講下php調(diào)試這一塊气破,由于網(wǎng)上及官方既有的一些代碼在調(diào)試時都會出現(xiàn)如下這一類似的錯誤:
Fatal error: Uncaught Error: Call to undefined method GearmanClient::do() in /mntxxx/client_gearman.php:4
Stack trace:
#0 {main}
thrown in /mntxxx/client_gearman.php on line 4
別的環(huán)境貌似不會聊浅,但php7環(huán)境下會出錯,下面貼上一段php7環(huán)境下Gearman調(diào)試無錯的代碼:
client端:
client.php
<?php
// Name of function
$funcName = 'generateReport';
// Data for function
$data = [
'report' => 'user_statistic',
];
$client = new GearmanClient();
$client->addServer('127.0.0.1', '4730');
$client->doBackground($funcName, json_encode($data));
Server端:
server.php
<?php
$worker = new GearmanWorker();
$worker->addServer();
$worker->addFunction('generateReport', 'generate');
$worker->work();
function generate($job)
{
$workload = $job->workload();
$data = json_decode($workload, true);
// do generate...
echo "generate... \n";
sleep(3);
//set status into db
echo "set status into db... \n";
sleep(2);
echo "done! \n";
}
在命令行先運行處理程序worker端
php server.php
再運行client端
php client.php
下面是返回信息现使,搞惦:
generate...
set status into db...
done!
至此低匙,該worker端處理器已經(jīng)完成他的工作,并已關(guān)閉碳锈,可通過gearadmin狀態(tài)監(jiān)測工具進行驗證顽冶。
gearadmin --status
111.jpg
上面這里,第一列指函數(shù)名稱注冊在服務(wù)器; 第二列指隊列中的任務(wù)數(shù); 第三列指在目前進行的任務(wù)數(shù); 第四列指處理器將與工作任務(wù)的數(shù)量售碳。
如果再次運行客戶端渗稍,你可以看到任務(wù)的隊列數(shù)量將增加:
php server.php
gearadmin --status
generateReport 1 1 1
gearadmin --status
generateReport 0 0 0
php server.php
gearadmin --status
generateReport 1 1 1
gearadmin --status
generateReport 0 0 0
gearadmin 工具佩迟,可以用
--workers參數(shù)查看當(dāng)前多少個worker都什么函數(shù)
11.png
--status參數(shù)查看當(dāng)前多少個worker啟動項
22.png
其他選項看下表
33.jpg