深入探讨pcntl_fork函数

上次“闲言之PHP不支持多线程”时,提到了PHP的原生fork进程函数pcntl_fork,其手册中官方文档介绍如下:

pcntl_fork  (PHP 4 >= 4.1.0, PHP 5, PHP 7)

"在当前进程当前位置产生分支(子进程),创建成功时,在父进程执行线程内返回产生的子进程的PID,在子进程执行线程内返回0,创建失败时,在父进程上下文返回-1,并且引发一个PHP错误。【tips: 子进程随时可通过getpid()以及getppid()获取自己和父进程的pid】

子进程创建成功后,父进程和子进程 都从fork的位置继续/开始向下执行。。。"

为了探究pcntl_fork对Web环境中对PHP解释执行的影响,我想有必要先了解下子进程和父进程在执行过程中有什么样的交互影响?

首先介绍下创建子进程的三种重要技术:

Fork,写时复制以及vfork技术的区别

转自:http://www.cnblogs.com/wanpengcoder/articles/5310331.html

在理解子进程和父进程的交互影响前,先要有一个实现上的意识即:进程——>虚拟地址空间——>物理地址空间。用户进程能感知的是进程的虚拟地址空间,而虚拟地址空间——>物理地址空间则是由底层的内核实现的。一个进程在地址空间上的表现形式就是:【主要部分】正文段、数据段、堆、栈,内核,内核会为这四部分分配相应的载体,即真正的物理存储。

Fork子进程

现有一个父进程P1,这是一个主体,虚拟地址空间与物理地址空间具有,现在在其虚拟地址空间(有相应的数据结构表示)上有:正文段,数据段,堆,栈这四个部分,相应的,内核要为这四个部分分配各自的物理块,即:正文段块,数据段块,堆块,栈块。至于内核如何分配,此处并不详述。

1. 现P1用fork函数为进程创建一个子进程P2,内核:i:复制P1的正文段,数据段,堆和栈四部分,注意其内容相同;ii:为这四个部分分配物理块;

P2:正文段->PI的正文段的物理块,即暂时不为P2分配正文段块;数据段->P2自己的数据段块(为其分配对应的块),堆->P2自己的堆块,栈->P2自己的栈块。如下图所示:同左到右大的方向箭头表示复制内容。

写时复制技术

内核只为新生成的子进程创建虚拟空间结构,它们复制于父进程的虚拟空间结构,但不为这些段分配物理内存,它们共享父进程的物理空间;当父子进程中有更改相应段的行为发生时,再为子进程相应的段分配物理空间;

 vfork()

此做法更是凶残,内核连子进程的虚拟地址空间结构也不创建了,直接共享父进程的虚拟空间和父进程的物理空间。

书接上文,fork子进程除了正文段【或代码空间】共享外,其他的物理空间都是独立的,在操作系统眼里它们更像是“兄弟关系”,各分炉灶,至于运行的具体先后情况就要看操作系统的调度算法了,如果父子进程间需要通信,比如同步协调啦,那么就要牵涉到进程通信方式:管道,消息队列,信号量,共享内存以及套接字等,甚至比如pcntl类的posix信号量。

讲到这里,pcntl_fork不适合用在Web环境下的原因应该也就清晰了,个人猜测有如下几点:

1. 对于访问情况不确定的Web环境而言,访问量、高并发的情况尚未可知,fork进程数不好控制,总不能把服务器进程搞炸了吧;

2. 如若访问及进程数量可控,纯粹是为了提升响应效率而采用多进程,那么由于fork的子进程和父进程异步执行,如若没有进程间通信控制,“僵尸进程”的出现也就不言而喻了;

3. 保持简单,PHP之所以成功就是其简单的每一个请求一次加载所有资源,处理完就释放所有资源,并发上来后应该通过缓存解决问题,任何性能相关的计算,可以转接到更为合适的语言上,比如Java。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容