1.1、源码

在之前的代码根本上,修正得到如下代码

<?php

php检测进程是否运行42php多过程运行留意事项 Node.js

$name = 'xiaobei';

$pid = pcntl_fork();

if ($pid<0) {

die(\"大众fork is error.\公众);

}

if ($pid===0) {

echo \"大众I am a child.-->\"大众,posix_getppid(),'-->',posix_getpid(),'->',$name,PHP_EOL;

exit;

while (1) {

echo time(),PHP_EOL;

sleep(2);

}

}

echo \"大众I am a father-->\公众,posix_getpid(),'-->',$name,PHP_EOL;

1.2、实行结果

截图的关系,程序还是每隔1s,输出当前韶光。
产生此结果的缘故原由是什么?

1.3、缘故原由解释

由于父进程先于子进程退出。
因此子进程就成了孤儿进程。
它被linux系统的1号进程收养,从而摆脱当前的运行终端。

那是否可以避免此种情形,或者说,当我们创建子进程后,一定要确保子进程完全退出后,父进程才退出

2、修正案例的源码

2.1、源码

<?php

/

Copyright (C) Iamasb

@project : 3、workerman干系知识点

@explain : fork子进程

@filename : fork.php

@author : iamasb

/

$name = 'xiaobei';

$pid = pcntl_fork();

if ($pid<0) {

die(\"大众fork is error.\公众);

}

if ($pid===0) {

echo \"大众I am a child.-->\公众,posix_getppid(),'-->',posix_getpid(),'->',$name,PHP_EOL;

while (1) {

echo time(),PHP_EOL;

sleep(2);

}

}

echo \"大众I am a father-->\"大众,posix_getpid(),'-->',$name,PHP_EOL;

// 非壅塞的运行办法

//while (1) {

// $pid = pcntl_wait($status,WNOHANG); // 非壅塞

// if ($pid>0) {

// echo 'exit->',$pid,'-->',$status,PHP_EOL;

// exit;

// }

//}

$pid = pcntl_wait($status,WUNTRACED); // 壅塞,直到子进程退出时,才返回

echo 'exit->',$pid,'-->',$status,PHP_EOL;

2.2、实行结果

备注: 由于当前输出信息,霸占了终端。
因此只能另开shell终端,并利用kill命令,杀去世子进程