PHP多程序處理任務

2021-09-29 19:22:30 字數 1525 閱讀 9733

系統 - linux

php 4 >= 4.1.0, php 5, php 7

擴充套件 -pcntlposixphp 多程序一般應用在 php_cli 命令列中執行 php 指令碼,不要在 web 訪問時使用。

多程序處理分解任務一般要比單程序更快。

php 檢視是否安裝多程序模組(pcntl 是 process control 的縮寫):

php -m | grep pcntl
建立子程序的函式 fork,了解過c語言的同學應該都知道這個。

php 多程序的一些庫函式手冊:

pcntl_fork — 在當前程序當前位置產生分支(子程序)。

譯註:fork 是建立了乙個子程序,父程序和子程序 都從 fork 的位置開始向下繼續執行,不同的是父程序執行過程中,得到的fork返回值為子程序號,而子程序得到的是0。

乙個 fork 子程序的基礎示例:

<?php

$pid

=pcntl_fork()

;// 父程序和子程序都會執行下面**if(

$pid==-

1)elseif(

$pid

)else

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

比如有乙個比較大的資料檔案要處理,這個檔案由很多行組成。如果單程序執行要處理的任務,量很大時要耗時比較久。這時可以考慮多程序。

多程序處理分解任務,每個程序處理檔案的一部分,這樣需要均分割一下這個大檔案成多個小檔案(程序數和小檔案的個數等同就可以)。

比如該檔案 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++

)elseif

($pid

)else

}// 等待子程序執行結束 必須否則子程序會成為殭屍程序

// pcntl_waitpid 掛起當前程序的執行直到引數pid指定的程序號的程序退出,或接收到乙個訊號要求中斷當前程序或呼叫乙個訊號處理函式。

while

(pcntl_waitpid(0

,$status)!=

-1)

PHP 多程序處理任務

乙個 php 多程序簡單例子大概是這個樣子 5 個子程序處理任務 for i 0 i 5 i elseif pid else 等待子程序執行結束 while pcntl waitpid 0 status 1 當然實際應用中我們不能夠這樣輸出 不夠健壯,也不夠優雅,我所以找了個基於pcntl封裝的擴充...

php利用多程序處理任務

注 php多程序一般應用在php cli命令列中執行php指令碼,做程序任務時要檢查php是否開啟了pcntl擴充套件,pcntl是process control程序管理的縮寫 pcntl fork 在當前程序當前位置產生分支 子程序 乙個fork子程序的基礎示例 pid pcntl fork 父程...

PHP利用多程序處理任務

php多程序一般應用在php cli命令列中執行php指令碼,不要在web訪問時使用。多程序處理分解任務一般要比單程序更快。php檢視是否安裝多程序模組 php m grep pcntl pcntl是process control的縮寫 建立子程序的函式fork,了解過c語言的同學應該都知道這個。p...