PHP简单实现多进程并行处理,子进程负责处理事物,父进程可控制子进程数量,用pcntl扩展实现(备注:在windows下此效果无法实现)
- /**
- * 入口函数
- * 将此文件保存为 ProcessOpera.php
- * 在terminal中运行 /usr/local/php/bin/php ProcessOpera.php &
- * 查看进程 ps aux|grep php
- */
-
-
- ProcessOpera("runCode", array(), 8);
-
- /**
- * run Code
- */
- function runCode($opt = array()) {
- //需要在守护进程中运行的代码
- }
-
- /**
- * $func为子进程执行具体事物的函数名称
- * $opt为$func的参数 数组形式
- * $pNum 为fork的子进程数量
- */
- function ProcessOpera($func, $opts = array(), $pNum = 1) {
- while(true) {
- $pid = pcntl_fork();
- if($pid == -1) {
- exit("pid fork error");
- }
- if($pid) {
- static $execute = 0;
- $execute++;
- if($execute >= $pNum) {
- pcntl_wait($status);
- $execute--;
- }
- } else {
- while(true) {
- //somecode
- $func($opts);
- sleep(1);
- }
- exit(0);
- }
- }
- }
复制代码
|