PHP-max_execution_time与fpm.request_terminate_timeout介绍
2020/3/5 5:01:24
本文主要是介绍PHP-max_execution_time与fpm.request_terminate_timeout介绍,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
前段时间一位同事跟我说php脚本超时时间以fpm配置优先。经过自己测试后,其实不然,前面的观点只是在某些情况下成立。
php脚本超时时间可以在php.ini的max_execution_time和fpm.conf的request_terminate_timeout参数两处进行设置.那么这两者有什么区别呢?
当我们设置php.ini的max_execution_time参数后,zend引擎处理脚本时,其内部会根据设定的时间定义一个定时器(setitimer),这是linux的API。
而fpm.confrequest_terminate_timeout的检测是通过主进程遍历定时事件fpm_pctl_heartbeat来判断PHP脚本执行是否超时。
下面通过实例进行分析。
example:
$a = time(); var_dump('begin'); for($i=0;;$i++){ if(time()-$a>10){ break; } } var_dump('end');
上面的代码比较容易理解,首先,输出“begin”字符串,10秒后再输出“end”字符串。
方案1:修改php.ini的配置max_execution_time=3,fpm.conf的request_terminate_timeout=20.
example执行的结果:
string(5) "begin"
1
chrome浏览器抓包:
根据上面运行的结果和效果图可以看出,example运行3秒后中止。也就是说,此时,php.ini的max_execution_time生效了。
方案2:修改php.ini的配置max_execution_time=20,fpm.conf的request_terminate_timeout=3.
example执行的结果:
chrome浏览器抓包:
从上面的截图可以看出,程序也只执行了3S。此时脚本的运行受到fpm.conf的request_terminate_timeout配置影响。
从上面两个方案推断出,对于example实例,php脚本取max_execution_time与request_terminate_timeout最小值作为脚本的超时时间。那是不是只要设置max_execution_time参数即可呢?
下面继续分析,我们对example代码稍微调整下。
$a = time(); var_dump('begin'); sleep(10); var_dump('end');
这段代码与上面功能类似,唯一的区别是由循环改成sleep()。
采用方案1的配置,结果如下:
string(5) "begin" string(3) "end"
1
采用方案2的配置,结果如下:
example执行的结果:
对比两个结果可以看出此时max_execution_time的配置未起到效果。以下是引用php手册的一段话(http://php.net/manual/zh/func...:
set_time_limit()函数和配置指令max_execution_time只影响脚本本身执行的时间。任何发生在诸如使用system()的系统调用,流操作,数据库操作等的脚本执行的最大时间不包括其中,当该脚本已运行。在测量时间是实值的Windows中,情况就不是如此了。
SO,为了保证生产环境的安全,建议同时设置max_execution_time和request_terminate_timeout参数值。
这篇关于PHP-max_execution_time与fpm.request_terminate_timeout介绍的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23怎么实现安卓+php 热更新方案?-icode9专业技术文章分享
- 2024-11-22PHP 中怎么实现判断多个值是否为空、null 或者为 false?-icode9专业技术文章分享
- 2024-11-11开源 PHP 商城项目 CRMEB 二次开发和部署教程
- 2024-11-09怎么使用php在kaufland平台刊登商品?-icode9专业技术文章分享
- 2024-11-05PHP的抽象类和接口是什么,有什么区别-icode9专业技术文章分享
- 2024-11-01开源 PHP 商城项目 CRMEB 安装和使用教程
- 2024-11-01用php和mysql写无限分类,有哪几种方法-icode9专业技术文章分享
- 2024-10-31php数据分表导出时部分数据无法导出什么原因-icode9专业技术文章分享
- 2024-10-30有经验的 PHP 开发者学习一门新的编程语言,有哪些推荐的有前景的语言-icode9专业技术文章分享
- 2024-10-21php 检测图片是否篡改过-icode9专业技术文章分享