1. 程式人生 > >PHP利用多程序處理任務(一篇寫得比較容易理解的多程序文章)

PHP利用多程序處理任務(一篇寫得比較容易理解的多程序文章)

 PHP多程序一般應用在PHP_CLI命令列中執行php指令碼,不要在web訪問時使用。

   多程序處理分解任務一般要比單程序更快。   php檢視是否安裝多程序模組:
php -m | grep pcntl

(pcntl是process control的縮寫)

  建立子程序的函式fork,瞭解過C語言的同學應該都知道這個。 php多程序的一些庫函式手冊: http://php.net/manual/zh/function.pcntl-fork.php
 pcntl_fork — 在當前程序當前位置產生分支(子程序)。譯註:fork是建立了一個子程序,父程序和子程序 都從fork的位置開始向下繼續執行,不同的是父程序執行過程中,得到的fork返回值為子程序號,而子程序得到的是0。 一個fork子程序的基礎示例: 
<?php

$pid = pcntl_fork();
//父程序和子程序都會執行下面程式碼
if ($pid == -1) {
    //錯誤處理:建立子程序失敗時返回-1.
     die('could not fork');
} else if ($pid) {
     //父程序會得到子程序號,所以這裡是父程序執行的邏輯
     pcntl_wait($status); //等待子程序中斷,防止子程序成為殭屍程序。
} else {
     //子程序得到的$pid為0, 所以這裡是子程序執行的邏輯。
}

 

如果一個任務被分解成多個程序執行,就會減少整體的耗時。

  比如有一個比較大的資料檔案要處理,這個檔案由很多行組成。如果單程序執行要處理的任務,量很大時要耗時比較久。這時可以考慮多程序。 多程序處理分解任務,每個程序處理檔案的一部分,這樣需要均分割一下這個大檔案成多個小檔案(程序數和小檔案的個數等同就可以)。   比如該檔案file.log有10萬行資料,現在想分4個程序處理。需要分割2.5萬行一個檔案。命令split可以做到。 split的用法比較簡單,可以man split檢視下手冊。   
split
-l 25000 -d file.log prefix_name

-l是按照行分割,-d是分割後的檔名按照數字,-a是分割後的檔案個數位數(預設是2,做多就是99個;比如超過100個,-a可以寫3)。自己嘗試分割一下就知道了。

處理程式碼:

<?php

shell_exec('split -l 25000 -d file.log prefix_name');

// 3個子程序處理任務
for ($i = 0; $i < 3; $i++){
    $pid = pcntl_fork();

    if ($pid == -1) {
        die("could not fork");

    } elseif ($pid) {
        echo "I'm the Parent $i\n";

    } else {// 子程序處理
        $content = file_get_contents("prefix_name0".$i);
        // 業務處理 begin

        // 業務處理 end

        exit;// 一定要注意退出子程序,否則pcntl_fork() 會被子程序再fork,帶來處理上的影響。
    }
}

// 等待子程序執行結束
while (pcntl_waitpid(0, $status) != -1) {
    $status = pcntl_wexitstatus($status);
    echo "Child $status completed\n";
}