php多进程pcntl学习-僵尸进程

 上个月写的文章,php多进程pcntl学习(一)现在发现并不完整,因为虽然提到了关闭子进程,但是并没有回收子进程,简单的说就是当子进程比父进程先退出,而父进程没对其做任何处理的时候,子进程将会变成僵尸进程。

<?php
$ppid = getmygid();
$pid = pcntl_fork();
if ($pid == -1){
die(‘fork failed‘);
}else if($pid == 0){
$mypid = getmygid();
echo ‘I am child process. My PID is ‘ . $mypid . ‘ and my father is‘,$ppid.PHP_EOL;
exit(); //关闭子进程 ,需要配合pcntl_wait使用 , 否则通过ps aux | grep php - >[php] <defunct> 僵尸进程
}else{
echo ‘Oh my god! I am a father now! My child is‘. $pid . ‘ and mine is ‘ . $ppid . PHP_EOL;
//pcntl_wait($status); //回收子进程,避免僵尸进程
}
//使主进程挂起
sleep(100);

  执行命令可以看见,子进程变为僵尸进程

  

  僵尸进程虽然不占什么内存,但是很碍眼,院子里一堆躺着的僵尸怎么都觉得怪怪的。(别忘了它们还占用着PID)

  把12行的注释打开,重新执行脚本测试 ps aux | grep php 可以发现子进程退出后就被回收了.顺便说下,通过信号也是能够做到的

  pcntl_signal(SIGCHLD, SIG_IGN);  //如果父进程不关心子进程什么时候结束,子进程结束后,内核会回收。 

  参考:http://www.jb51.net/article/56301.htm

原文地址:https://www.cnblogs.com/php-linux/p/10421244.html

时间: 2024-08-29 00:49:38

php多进程pcntl学习-僵尸进程的相关文章

php多进程pcntl学习(补漏)

上个月写的文章,php多进程pcntl学习(一)现在发现并不完整,因为虽然提到了关闭子进程,但是并没有回收子进程,简单的说就是当子进程比父进程先退出,而父进程没对其做任何处理的时候,子进程将会变成僵尸进程. 1 <?php 2 $ppid = getmygid(); 3 $pid = pcntl_fork(); 4 if ($pid == -1){ 5 die('fork failed'); 6 }else if($pid == 0){ 7 $mypid = getmygid(); 8 echo

php多进程 防止出现僵尸进程

对于用PHP进行多进程并发编程,不可避免要遇到僵尸进程的问题. 僵尸进程是指的父进程已经退出,而该进程dead之后没有进程接受,就成为僵尸进程(zombie)进程.任何进程在退出前(使用exit退出) 都会变成僵尸进程(用于保存进程的状态等信息),然后由init进程接管.如果不及时回收僵尸进程,那么它在系统中就会占用一个进程表项,如果这种僵尸进程过多,最后系统就没有可以用的进程表项,于是也无法再运行其它的程序. 方法一: 父进程通过pcntl_wait和pcntl_waitpid等函数等待子进程

php多进程防止出现僵尸进程

对于用PHP进行多进程并发编程,不可避免要遇到僵尸进程的问题. 僵尸进程是指的父进程已经退出,而该进程dead之后没有进程接受,就成为僵尸进程(zombie)进程.任何进程在退出前(使用exit退出) 都会变成僵尸进程(用于保存进程的状态等信息),然后由init进程接管.如果不及时回收僵尸进程,那么它在系统中就会占用一个进程表项,如果这种僵尸进程过多,最后系统就没有可以用的进程表项,于是也无法再运行其它的程序. 方法一: 父进程通过pcntl_wait和pcntl_waitpid等函数等待子进程

php多进程pcntl学习

pcntl在windows下无法使用,linux编译php时加上参数--enable-pcntl 即可.第一次使用pcntl模块,遇到了一些坑也慢慢填上了,这里简单记录下. 1. 子进程之间变量无法共享. 2. 子进程完成,记得加上exit(),子进程退出,否则会有坑. 1 <?php 2 $pid_dir = __DIR__.'/pid_files/'; 3 4 for ($i=0;$i<3;$i++){ 5 $pid = pcntl_fork(); 6 if ($pid == -1){ 7

php多进程pcntl学习(二)

多进程中数据独立,变量无法共享,所以可以使用shmop共享内存实现(cli模式不支持APC扩展),或者存储到redis这种nosql中. 下面实例,开10个进程结合redis集合,做一些简单的任务处理. 1 <?php 2 for ($i=0;$i<10;$i++){//开10个进程 3 $ret = pcntl_fork(); //生成进程 4 5 if ($ret == 0){ 6 7 $redis = new Redis(); 8 $redis->connect('127.0.0.

php多进程pcntl学习(采集新浪微博)

上面2篇文都简明了多进程中一些需要注意的地方,这次用多进程配合curl_mulit_*来做新浪微博的采集. 先把知识点和值得注意的坑列出 /* 需求:开3个进程,并且模拟多线程来采集新浪微博用户信息,cookie用本博客模拟登陆微博文章生成的cookie 知识要点: 1.需要把抓去过的 url放在容器里,请求前比对下即可避免重复抓取.(此程序没有判断,本人比较懒,哎) 2.容器不能为变量,开多个进程会出现问题,因为进程之间数据独立,无法共享.可以使用shmop共享内存实现(cli不支持模式APC

【C/C++】多进程:僵尸进程

一个僵尸进程产生的过程是:父进程调用fork创建子进程后,子进程运行至其终止.进程终止后有些信息对于父进程和内核还是很有用的,例如进程的ID号.进程的退出状态.进程运行的CPU时间等.因此进程运行终止后,系统会回收所有内核分配给它的内存.关闭它所打开的文件等,但是还会保留以上极少的信息,以供父进程使用,系统会向父进程发送SIGCHLD信号,父进程应及时调用wait函数来为子进程收尸,做一些收尾工作.但如果父进程没有及时调用wait函数,则子进程的进程状态变成ZOMBIE,即僵尸进程.僵尸进程会一

菜鸟随笔(3)---三种进程学习.孤儿进程.僵尸进程.守护进程

一只菜鸟横空出世,码农世界闯一闯,每天进展多一丢丢. 三种进程学习.孤儿进程.僵尸进程.守护进程 转自https://blog.csdn.net/believe_s/article/details/77040494 1.孤儿进程 如果父进程先退出,子进程还没退出那么子进程将被 托孤给init进程,这里子进程的父进程就是init进程(1号进程).其实还是很好理解的. // 父进程先子进程退出 // 子进程会被祖父进程接手并在后台运行,执行内部的代码 int main() { pid_t pid =

【Todo】僵尸进程学习 &amp; 进程状态列表

参考这篇文章: http://www.mike.org.cn/articles/treatment-of-zombie-processes-under-linux/ 在Linux进程的状态中,僵尸进程是非常特殊的一种,它已经放弃了几乎所有内存空间,没有任何可执行代码,也不能被调度,仅仅在进程列表中保留一个位置,记载该进程的退出状态等信息供其他进程收集,除此之外,僵尸进程不再占有任何内存空间.它需要它的父进程来为它收尸. 如果他的父进程没安装SIGCHLD信号处理函数,也没有调用wait或wait