PHP在非常多时候不适合做常驻的SHELL进程, 他没有专门的gc例程, 也没有有效的内存管理途径. 所以假设用PHP做常驻SHELL, 你会常常被内存耗尽导致abort而unhappy

并且, 假设输入数据非法, 而脚本没有检測, 导致abort, 也会让你非常不开心. 



那? 怎么办呢? 



多进程…. 



为什么呢? 



长处: 

1. 使用多进程, 子进程结束以后, 内核会负责回收资源 

2. 使用多进程,子进程异常退出不会导致整个进程Thread退出. 父进程还有机会重建流程. 

3. 一个常驻主进程, 仅仅负责任务分发, 逻辑更清楚 



Then, 怎么做呢? 



接下来, 我们使用PHP提供的POSIX和Pcntl系列函数, 来实现一个PHP命令解析器, 主进程负责接受用户输入, 然后fork子进程运行, 并负责回显子进程的结束状态. 



代码例如以下, 我加了凝视, 假设有不懂的地方, 能够翻阅手冊相关函数, 或者回复留言.



代码例如以下:


#!/bin/env php 

<?php 

/** A example denoted muti-process application in php 

* @filename fork.php 

* @touch date Wed 10 Jun 2009 10:25:51 PM CST 

* @author Laruence<laruence@baidu.com> 

* @license http://www.zend.com/license/3_0.txt PHP License 3.0 

* @version 1.0.0 

*/ 



/** 确保这个函数仅仅能执行在SHELL中 */ 

if (substr(php_sapi_name(), 0, 3) !== 'cli') { 

die("This Programe can only be run in CLI mode"); 





/** 关闭最大运行时间限制, 在CLI模式下, 这个语句事实上不必要 */ 

set_time_limit(0); 



$pid = posix_getpid(); //取得主进程ID 

$user = posix_getlogin(); //取得username 



echo <<<EOD 

USAGE: [command | expression] 

input php code to execute by fork a new process 

input quit to exit 



Shell Executor version 1.0.0 by laruence 

EOD; 



while (true) { 



$prompt = "\n{$user}$ "; 

$input = readline($prompt); 



readline_add_history($input); 

if ($input == 'quit') { 

break; 



process_execute($input . ';'); 





exit(0); 



function process_execute($input) { 

$pid = pcntl_fork(); //创建子进程 

if ($pid == 0) {//子进程 

$pid = posix_getpid(); 

echo "* Process {$pid} was created, and Executed:\n\n"; 

eval($input); //解析命令 

exit; 

} else {//主进程 

$pid = pcntl_wait($status, WUNTRACED); //取得子进程结束状态 

if (pcntl_wifexited($status)) { 

echo "\n\n* Sub process: {$pid} exited with {$status}"; 








但有一点, 我一定要提醒:



代码例如以下:


Process Control should not be enabled within a webserver environment and unexpected results may happen if any Process Control functions are used within a webserver environment. --摘自PHP手也就是说, 打消你在PHP Web开发中使用多进程的念头吧! 

PHP CLI模式下的多进程应用分析的更多相关文章

  1. PHP CLI模式下的多进程应用

    作者: Laruence(   ) 本文地址: http://www.laruence.com/2009/06/11/930.html 转载请注明出处 PHP在很多时候不适合做常驻的SHELL进程, ...

  2. php cli模式下获取参数的方法

    转载声明:http://blog.csdn.net/fdipzone/article/details/51945892 php在cli模式下接收参数有两种方法 1.使用argv数组 <?php ...

  3. php在cli模式下取得命令行中的参数的方法-getopt命令行可传递数组-简单自定义方法取命令行参数

    在cli模式下执行PHP时,自动给脚本文件传递了一个变量$argv,其值即是一个命令中所有值组成的数组(以空格区分),在PHP程序中接收参数有3种方法1.直接使用argv变量数组. 2.使用$_SER ...

  4. PHP CLI模式下echo换行

    近日在执行导库程序的时候,需要在CLI模式下运行程序进行调试,如下图,这是什么鬼?不是我想要的结果 后经过查资料发现代码中执行的输出为 //错误方法实例 echo '其他-683\n'; //正确打开 ...

  5. 解决 php7 cli 模式下中文乱码的两中方法

    解决 php7 cli 模式下中文乱码的两中方法1. 给PHP文件开头加上 exec('chcp 936'); 然后把该文件以 ANSI 格式编码2. 在 php.ini 中设置 default_ch ...

  6. DexHunter在ART虚拟机模式下的脱壳原理分析

    本文博客地址: http://blog.csdn.net/qq1084283172/article/details/78494620 DexHunter脱壳工具在Dalvik虚拟机模式下的脱壳原理分析 ...

  7. php CLI 模式下的传参方法

    在CLI模式(命令行界面 Command Line Interface)下,传入参数有如下3种方法: 一. getopt函数(PHP 4 >= 4.3.0, PHP 5) getopt - 从命 ...

  8. Php cli模式下执行报错/usr/bin/php: /usr/local/lib/libxml2.so.2: no version information available (required by /usr/bin/php)

    centos下php cli模式报错 /usr/bin/php: /usr/local/lib/libxml2.so.2: no version information available (requ ...

  9. DexHunter在Dalvik虚拟机模式下的脱壳原理分析

    本文博客地址:http://blog.csdn.net/qq1084283172/article/details/78494671 在前面的博客<DexHunter的原理分析和使用说明(一)&g ...

随机推荐

  1. 44.AngularJS Bootstrap

    转自:https://www.cnblogs.com/best/tag/Angular/ Bootstrap 你可以在你的 AngularJS 应用中加入 Twitter Bootstrap,你可以在 ...

  2. springboot shiro配置

    导入相关包(这里配合使用Ehcache缓存) <dependency> <groupId>org.apache.shiro</groupId> <artifa ...

  3. spring boot自动配置之jdbc

    1.DataSource配置 1.1 默认配置application.xml spring.datasource.url=jdbc:mysql://localhost/test spring.data ...

  4. P1452 Beauty Contes(旋转卡壳版)

    题目背景 此处省略1W字^ ^ 题目描述 贝茜在牛的选美比赛中赢得了冠军”牛世界小姐”.因此,贝西会参观N(2 < = N < = 50000)个农场来传播善意.世界将被表示成一个二维平面 ...

  5. 用VUE做网站后台

    介绍: 这是一个用vuejs2.0和element搭建的后台管理界面. 相关技术: vuejs2.0:渐进式JavaScript框架,易用.灵活.高效,似乎任何规模的应用都适用. element:基于 ...

  6. CF983E NN country(倍增,差分)

    题意 给定一棵树和若干条路线,每条路线相当于树上 x,y 之间的路径,途径路径上的每个点 给出若干个询问,每次询问从 u 到 v 至少需要利用几条路线 N,M,Q≤200000 题解 构建倍增数组g[ ...

  7. caioj 1106 树形动态规划(TreeDP)1:加分二叉树

    解这道题的前提是非常熟悉中序遍历的方式 我就是因为不熟悉而没有做出来 中序遍历是5 7 1 2 10的话,如果1是根节点 那么5 7 1就是1的左子树,2, 10就是右子树 这就有点中链式dp的味道了 ...

  8. 洛谷 P1176 路径计数2

    P1176 路径计数2 题目描述 一个N×N的网格,你一开始在(1, 1),即左上角.每次只能移动到下方相邻的格子或者右方相邻的格子,问到达(N, N),即右下角有多少种方法. 但是这个问题太简单了, ...

  9. mysql生成随机时间

    mysql> update test set create_time=concat('2013-10-01 ', floor(10+rand()*10),':',floor(10+rand()* ...

  10. POJ 1088: 滑雪(经典 DP+记忆化搜索)

    滑雪 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 74996   Accepted: 27818 Description ...