电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

php 的多進程操作實踐案例分析

瀏覽:141日期:2022-09-11 13:01:58

本文實例講述了php 的多進程操作。分享給大家供大家參考,具體如下:

php的多進程處理依賴于pcntl擴展,通過pcntl_fork創建子進程來進行并行處理。

例1如下:

<?php$pid = pcntl_fork();if($pid == -1) { //錯誤處理:創建子進程失敗時返回-1. die(’fork error’);} else if ($pid) { //父進程會得到子進程號,所以這里是父進程執行的邏輯 echo 'parent n'; //等待子進程中斷,防止子進程成為僵尸進程。 pcntl_wait($status);} else { //子進程得到的$pid為0, 所以這里是子進程執行的邏輯。 echo 'child n'; exit;}

pcntl_fork創建了子進程,父進程和子進程都繼續向下執行,而不同是父進程會獲取子進程的$pid也就是$pid不為零。而子進程會獲取$pid為零。通過if else語句判斷$pid我們就可以在指定位置寫上不同的邏輯代碼。

上述代碼會分別輸出parent和child。那么輸出的parent和child是否會有順序之分?是父進程會先執行?

例2如下:

<?php$pid = pcntl_fork();if($pid == -1) { die(’fork error’);} else if ($pid) { sleep(3); echo 'parent n'; pcntl_wait($status);} else { echo 'child n'; exit;}

我們在父進程中通過sleep來延緩執行,看看效果。

結果是,很快輸出了child,等待了接近3秒后,才輸出parent。所以父進程和子進程的執行是相對獨立的,沒有先后之分。

那么問題又來了?pcntl_wait是做什么用的?會掛起當前進程,直到子進程退出,如果子進程在調用此函數之前就已退出,此函數會立刻返回。子進程使用的資源將被釋放。

例3如下:

<?php$pid = pcntl_fork();if($pid == -1) { die(’fork error’);} else if ($pid) { pcntl_wait ($status); echo 'parent n';} else { sleep(3); echo 'child n'; exit;}

上述代碼,我們可以看到,父進程執行pcntl_wait時就已經掛起,直到等待3秒后輸出child,子進程退出后。父進程繼續執行,輸出parent。

例4如下:

<?phpdefine(’FORK_NUMS’, 3);$pids = array();for($i = 0; $i < FORK_NUMS; ++$i) { $pids[$i] = pcntl_fork(); if($pids[$i] == -1) { die(’fork error’); } else if ($pids[$i]) { pcntl_waitpid($pids[$i], $status); echo 'pernet n'; } else { sleep(3); echo 'child id:' . getmypid() . ' n'; exit; }}

上述代碼,我們創建3個子進程,父進程分別掛起等待子進程結束后,輸出parent。

輸出結果如下:

child id:19090pernetchild id:19091pernetchild id:19092pernet

例5如下:

<?phpdefine(’FORK_NUMS’, 3);$pids = array();for($i = 0; $i < FORK_NUMS; ++$i) { $pids[$i] = pcntl_fork(); if($pids[$i] == -1) { die(’fork error’); } else if ($pids[$i]) { } else { sleep(3); echo 'child id:' . getmypid() . ' n'; exit; }}foreach($pids as $k => $v) { if($v) { pcntl_waitpid($v, $status); echo 'parent n'; }}

輸出結果如下:

child id:19118child id:19119child id:19120parentparentparent

為什么上述代碼跟例4的輸出結果不一樣?

我們可以看到例5的pcntl_waitpid函數放在了foreach中,foreach代碼是在主進程中,也就是父進程的代碼中。當執行foreach時,可能子進程已經全部執行完畢并退出。pcntl_waitpid會立刻返回,連續輸出三個parent。

(*在子進程中,需通過exit來退出,不然會產生遞歸多進程,父進程中不需要exit,不然會中斷多進程。)

例6如下:

<?phpdefine(’FORK_NUMS’, 3);$pids = array();$fp = fopen(’./test.log’, ’wb’);$num = 1;for($i = 0; $i < FORK_NUMS; ++$i) { $pids[$i] = pcntl_fork(); if($pids[$i] == -1) { die(’fork error’); } else if ($pids[$i]) { } else { for($i = 0; $i < 5; ++$i) { flock($fp, LOCK_EX); fwrite($fp, getmypid() . ’ : ’ . date(’Y-m-d H:i:s’) . ' : {$num} rn'); flock($fp, LOCK_UN); echo getmypid(), ': success rn'; ++$num; } exit; }}foreach($pids as $k => $v) { if($v) { pcntl_waitpid($v, $status); }}fclose($fp);

代碼如上:我們創建三個子進程,來同時向test.log文件寫入內容,test.log內容如下:

19507 : 2016-03-16 20:40:52 : 119507 : 2016-03-16 20:40:52 : 219507 : 2016-03-16 20:40:52 : 319507 : 2016-03-16 20:40:52 : 419507 : 2016-03-16 20:40:52 : 519509 : 2016-03-16 20:40:52 : 119509 : 2016-03-16 20:40:52 : 219509 : 2016-03-16 20:40:52 : 319509 : 2016-03-16 20:40:52 : 419509 : 2016-03-16 20:40:52 : 519508 : 2016-03-16 20:40:52 : 119508 : 2016-03-16 20:40:52 : 219508 : 2016-03-16 20:40:52 : 319508 : 2016-03-16 20:40:52 : 419508 : 2016-03-16 20:40:52 : 5

我們可以看到三個子進程的pid,它們分別執行了5次,時間幾乎是在同時。但是$num的值并沒像我們期望的那樣從1-15進行遞增。子進程中的變量是各自獨立的,互不影響。子進程會自動復制父進程空間里的變量。

如何在進程中共享數據?

我們通過php的共享內存函數shmop來實現。

<?phpdefine(’FORK_NUMS’, 3);$pids = array();$fp = fopen(’./test.log’, ’wb’);$num = 1;//共享內存段的key$shmKey = 123;//創建共享內存段$shmId = shmop_open($shmKey, ’c’, 0777, 64);//寫入數據到共享內存段shmop_write($shmId, $num, 0);for($i = 0; $i < FORK_NUMS; ++$i) { $pids[$i] = pcntl_fork(); if($pids[$i] == -1) { die(’fork error’); } else if ($pids[$i]) { //阻塞,等待子進程退出 //注意這里,如果是非阻塞的話,$num的計數會出現問題。 pcntl_waitpid($pids[$i], $status); } else { //讀取共享內存段中的數據 $num = shmop_read($shmId, 0, 64); for($i = 0; $i < 5; ++$i) { fwrite($fp, getmypid() . ’ : ’ . date(’Y-m-d H:i:s’) . ' : {$num} rn'); echo getmypid(), ': success rn'; //遞增$num $num = intval($num) + 1; } //寫入到共享內存段中 shmop_write($shmId, $num, 0); exit; }}//shmop_delete不會實際刪除該內存段,它將該內存段標記為刪除。shmop_delete($shmId);shmop_close($shmId);fclose($fp);

上述代碼的運行結果如下:

19923 : 2016-03-17 00:05:18 : 119923 : 2016-03-17 00:05:18 : 219923 : 2016-03-17 00:05:18 : 319923 : 2016-03-17 00:05:18 : 419923 : 2016-03-17 00:05:18 : 519924 : 2016-03-17 00:05:18 : 619924 : 2016-03-17 00:05:18 : 719924 : 2016-03-17 00:05:18 : 819924 : 2016-03-17 00:05:18 : 919924 : 2016-03-17 00:05:18 : 1019925 : 2016-03-17 00:05:18 : 1119925 : 2016-03-17 00:05:18 : 1219925 : 2016-03-17 00:05:18 : 1319925 : 2016-03-17 00:05:18 : 1419925 : 2016-03-17 00:05:18 : 15

這樣我們就在進程間共享了$num的數據。

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP進程與線程操作技巧總結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

標簽: PHP
相關文章:
主站蜘蛛池模板: 低噪声电流前置放大器-SR570电流前置放大器-深圳市嘉士达精密仪器有限公司 | (中山|佛山|江门)环氧地坪漆,停车场地板漆,车库地板漆,聚氨酯地板漆-中山永旺地坪漆厂家 | 盘煤仪,盘料仪,盘点仪,堆料测量仪,便携式激光盘煤仪-中科航宇(北京)自动化工程技术有限公司 | 无纺布包装机|径向缠绕包装机|缠绕膜打包机-上海晏陵智能设备有限公司 | 西安中国国际旅行社(西安国旅)| 幂简集成 - 品种超全的API接口平台, 一站搜索、试用、集成国内外API接口 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 酒吧霸屏软件_酒吧霸屏系统,酒吧微上墙,夜场霸屏软件,酒吧点歌软件,酒吧互动游戏,酒吧大屏幕软件系统下载 | 金属雕花板_厂家直销_价格低-山东慧诚建筑材料有限公司 | 进口消泡剂-道康宁消泡剂-陶氏消泡剂-大洋消泡剂 | 安驭邦官网-双向万能直角铣头,加工中心侧铣头,角度头[厂家直销] 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 蒸汽吸附分析仪-进口水分活度仪|康宝百科 | 楼承板-开口楼承板-闭口楼承板-无锡海逵| 接地电阻测试仪[厂家直销]_电缆故障测试仪[精准定位]_耐压测试仪-武汉南电至诚电力设备 | 钢丝绳探伤仪-钢丝绳检测仪-钢丝绳探伤设备-洛阳泰斯特探伤技术有限公司 | 江苏全风,高压风机,全风环保风机,全风环形高压风机,防爆高压风机厂家-江苏全风环保科技有限公司(官网) | 骨密度仪-骨密度测定仪-超声骨密度仪-骨龄测定仪-天津开发区圣鸿医疗器械有限公司 | 高压微雾加湿器_工业加湿器_温室喷雾-昌润空气净化设备 | ptc_浴霸_大巴_干衣机_呼吸机_毛巾架_电动车加热器-上海帕克 | 常州翔天实验仪器厂-恒温振荡器-台式恒温振荡器-微量血液离心机 恒温恒湿箱(药品/保健品/食品/半导体/细菌)-兰贝石(北京)科技有限公司 | 外贮压-柜式-悬挂式-七氟丙烷-灭火器-灭火系统-药剂-价格-厂家-IG541-混合气体-贮压-非贮压-超细干粉-自动-灭火装置-气体灭火设备-探火管灭火厂家-东莞汇建消防科技有限公司 | 北京中创汇安科贸有限公司| 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | 济南网站建设_济南网站制作_济南网站设计_济南网站建设公司_富库网络旗下模易宝_模板建站 | 空气能暖气片,暖气片厂家,山东暖气片,临沂暖气片-临沂永超暖通设备有限公司 | 通信天线厂家_室分八木天线_对数周期天线_天线加工厂_林创天线源头厂家 | 渗透仪-直剪仪-三轴仪|苏州昱创百科 | 企业微信营销_企业微信服务商_私域流量运营_艾客SCRM官网 | 干式变压器厂_干式变压器厂家_scb11/scb13/scb10/scb14/scb18干式变压器生产厂家-山东科锐变压器有限公司 | 上海办公室装修_上海店铺装修公司_厂房装潢设计_办公室装修 | 济南侦探调查-济南调查取证-山东私家侦探-山东白豹调查咨询公司 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 防水接头-电缆防水接头-金属-电缆密封接头-不锈钢电缆接头 | 山东信蓝建设有限公司官网 | 3d可视化建模_三维展示_产品3d互动数字营销_三维动画制作_3D虚拟商城 【商迪3D】三维展示服务商 广东健伦体育发展有限公司-体育工程配套及销售运动器材的体育用品服务商 | 浙江自考_浙江自学考试网 | 中高频感应加热设备|高频淬火设备|超音频感应加热电源|不锈钢管光亮退火机|真空管烤消设备 - 郑州蓝硕工业炉设备有限公司 | 破碎机锤头_合金耐磨锤头_郑州宇耐机械工程技术有限公司 | 二手回收公司_销毁处理公司_设备回收公司-找回收信息网 | 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 | 西门子伺服电机维修,西门子电源模块维修,西门子驱动模块维修-上海渠利 | 无刷电机_直流无刷电机_行星减速机-佛山市藤尺机电设备有限公司 无菌检查集菌仪,微生物限度仪器-苏州长留仪器百科 |