PHP Gearman擴展是一個用于與 Gearman 通訊的擴展,允許開發者跨語言、分布式執行任務的能力。在 PHP 項目很少使用并發和多線程的情況下,Gearman 擴展可以幫助用戶在一組異構系統、多線程模式下完成任務。
由于 Gearman 可以使用不同的編程語言和服務器進行異步任務的傳輸和處理,Gearman 擴展能夠幫助 PHP 開發者將復雜的任務進行并行和分布式處理,減少了運行時間和提高了生產力。
$gmclient = new GearmanClient();
$gmclient->addServer(); //默認機器localhost
echo $gmclient->doNormal("reverse","Hello!");
上述代碼中,我們使用 GearmanClient 對象來初始化了客戶端。addServer() 方法告訴 Gearman 服務器連接信息。接著使用 doNormal 方法來提交一個任務。這個任務名為 "reverse",任務參數為 "Hello!",它將簡單地返回反轉后的字符串。doNormal 方法返回代碼值,告訴我們這個任務是否被成功接受。如果返回 false,意味著將沒有 Worker 服務可以處理這個任務。
Gearman 擴展提供了多個方法,以及 GearmanWorker 類(用于創建 Gearman Workers)和 GearmanJob 類(用于處理傳入的任務)。這些方法可以幫助開發者針對性地控制任務、傳輸和處理機制。在使用 Gearman 執行 PHP 任務之前,必須先安裝并啟動 Gearman 服務器。
# 創建 GearmanWorker 實例
$gmworker= new GearmanWorker();
# 添加 Server
$gmworker->addServer();
# 添加反轉作業
$gmworker->addFunction("reverse", "reverse_fn");
while($gmworker->work())
{
if ($gmworker->returnCode() != GEARMAN_SUCCESS)
{
echo "Error: " . $gmworker->error() . "\n";
break;
}
}
function reverse_fn($job)
{
return strrev($job->workload());
}
上述代碼樣例中,我們使用 GearmanWorker 對象創建了一個 Worker。使用 addServer() 方法將 GearmanWorker 連接到服務器。接著使用 addFunction() 方法來注冊反轉函數 reverse_fn。這個函數將被調用以反轉字符串作為任務的標識符傳遞給 doNormal 方法。在交付任務之前,我們使用 work() 方法來與 Gearman 服務器建立連接。
代碼中的 while 循環保持它接收的任務的處理,同時也要檢測任務是否出現錯誤。 GearmanWorker 調用了 returnCode() 方法以提供是否處理成功的信息。如果返回的不是 GEARMAN_SUCCESS,我們將會從當前 while 循環中退出,并在屏幕上顯示一條錯誤消息。
在反轉函數 reverse_fn 中,我們定義了任務的處理機制。這個函數簡單的反轉了傳入字符串的順序并返回結果。在這個例子中,該函數作為回調函數傳遞給 addFunction() 方法。在實際的項目中,開發者可以選擇使用不同的任務和回調函數組合,來對應特定的業務需求。
使用 Gearman 擴展,開發者可以生成執行多個語言的并行任務,跟蹤執行進度,以及執行長時間運行的任務,而不需要阻塞 Web 服務器或消耗服務器資源。在大型應用和非常復雜的數據處理時,Gearman 擴展是一個非常強大的實用工具。