多進程案例

PHP的pcntl多進程

2013-07-26 18:03 by 軒脈刃, 11446 閱讀, 5 評論, 收藏編輯html

PHP使用PCNTL系列的函數也能作到多進程處理一個事務。好比我須要從數據庫中獲取80w條的數據,再作一系列後續的處理,這個時候,用單進程?你能夠等到明年今天了。。。因此應該使用pcntl函數了。數據庫

假設我想要啓動20個進程,將1-80w的數據分紅20份來作,主進程等待全部子進程都結束了才退出:數組

1函數

2post

3this

4spa

5code

6htm

7blog

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

$max = 800000;

$workers = 20;

 

$pids = array();

for($i = 0; $i < $workers; $i++){

    $pids[$i] = pcntl_fork();

    switch ($pids[$i]) {

        case -1:

            echo "fork error : {$i} \r\n";

            exit;

        case 0:

            $param = array(

                'lastid' => $max / $workers * $i,

                'maxid' => $max / $workers * ($i+1),

            );

            $this->executeWorker($input, $output, $param);

            exit;

        default:

            break;

    }

}

 

foreach ($pids as $i => $pid) {

    if($pid) {

        pcntl_waitpid($pid, $status);

    }

}

這裏當pcntl_fork出來之後,會返回一個pid值,這個pid在子進程中看是0,在父進程中看是子進程的pid(>0),若是pid爲-1說明fork出錯了。

使用一個$pids數組就能夠讓主進程等候全部進程完結以後再結束了

相關文章
相關標籤/搜索