[php]配置文件中的超时时间
概要
php.ini
l max_execution_time
l max_input_time
php-fpm.conf
l process_control_timeout
l request_terminate_timeout
l request_slowlog_timeout
max_execution_time与max_input_time
max_execution_time
描述:每个脚本最大可执行时间,cli模式下为0
max_input_time
描述:每个脚本花在解析请求数据上的最大时间,cli模式下为-1
三个阶段
l php_module_startup
l php_request_startup
l php_execute_script
两种情况
l max_input_time != -1
l php_module_startup阶段赋值EG(timeout_seconds)=max_execution_time
l php_request_startup阶段设置定时器,时间为max_input_time
l php_execute_script阶段重设定时器,时间为max_execution_time
总结:此时php脚本执行的最大时间为max_input_time+max_execution_time
l max_input_time = -1
l php_module_startup阶段赋值EG(timeout_seconds)=max_execution_time
l php_request_startup与php_execute_script阶段设置一个定时器,时间为EG(timeout_seconds)
总结:此时php脚本执行的最大时间为max_execution_time
总结:定时器时间算的是占用cpu的大时间(包括用户态以及内核态),而sleep()这样的系统调用会让进程挂起,不占用cpu时间,因此max_input_time以及max_execution_time时间不包括sleep的
process_control_timeout
描述:process_control_timeout是留给子进程处理来自master进程信号的时间限制
分析:master根据接收到的信号以及当前的大fpm运行状态决定发送给worker进程的是SIGQUIT还是SIGTERM,同时注册时间为process_control_timeout的定时时间,如果在process_control_timeout时间内子进程没退出,master就会升级信号,SIHQUIT->SIGTERM,SIGTERM->SIGKILL,当信号为SIGTERM时还会注册1s的定时事件,留多1秒给worker进程结束,1秒后还未结束,信号升级为SIGKILL,直接终止worker进程
request_terminate_timeout与request_slowlog_timeout
request_terminate_timeout
描述:执行一个请求的超时时间,在这之后worker进程将被终止。(官方解析:此选项应该用在max_execution_time不能被停止脚本执行的时候)
此处引用两个例子来进行说明
例子1代码:
<?php
$a = time();
echo ‘begin’;
for ($i = 0;;$i++) {
if (time() - $ime > 10) {
break;
}
}
echo ‘end’;
?>
例子2代码:
<?php
echo ‘begin’;
sleep(10);
echo ‘end’;
?>
l max_execution_time为20,request_terminate_timeout为3
例子1结果:出现报错,程序执行时间为3秒
例子2结果:出现报错,程序执行时间为3秒
l max_execution_time为3,request_terminate_timeout为20
例子1结果:程序终止,程序运行时间为3秒
例子2结果:结果正常
总结:max_execution_time算的是占用cpu的时间(也就是脚本自身执行的时间)类似system(),sleep(),操作数据库等的时间不算在内;request_terminate_timeout算的是worker的时间;
request_slowlog_timeout
描述:执行一个请求的超时时间,在这之后的php的backtrace会被输出到slowlog中
master心跳检测中心跳时间heartbeat的简化算法
算法目的:查看worker进程状态,其中包括是否已超时
规则:
- 开启reqeust_terminate_timeout的情况下:heartbeat = reqeust_terminate_timeout/1000*3
- 未开启request_terminate_timeout的情况下:heartbeat = request_slowlog_timeout/1000*3或者为0
- request_terminate_timeout >= request_slowlog_timeout
ps:此处如果由于request_terminate_timeout导致超时的发生的话,会直接kille掉worker进程,之后内核挥手client_socket,nginx返回502错误给客户端
[php]配置文件中的超时时间的更多相关文章
- 在使用jjwt时在配置文件中设置过期时间,取到的结果为0的原因
在设置了过期时间后感觉没有起作用,打印日志查看了下为0,因为生成token的文件在一个公共模块中,而过期时间设置在服务模块 中的配置文件中. 原因是:没有为设置getter和setter方法 来自为知 ...
- nginx中的超时配置
nginx.conf配置文件中timeout超时时间设置 client_header_timeout 语法 client_header_timeout time默认值 60s上下文 http serv ...
- 【Spring Cloud 源码解读】之 【如何配置好OpenFeign的各种超时时间!】
关于Feign的超时详解: 在Spring Cloud微服务架构中,大部分公司都是利用Open Feign进行服务间的调用,而比较简单的业务使用默认配置是不会有多大问题的,但是如果是业务比较复杂,服务 ...
- 设置linux中tcp默认的20秒connect超时时间(转)
无论你用任何语言或者是网络库,你都可以设置网络操作的超时时间,特别是connect.read.write的超时时间. 你可以在代码中把超时时间设置任意大小值,但是connect方法会有一点特殊. co ...
- 设置php下载文件的超时时间
使用curl 可以使用curl自己实现一个curl_file_get_contents函数 //CURLOPT_FOLLOWLOCATION TRUE 时将会根据服务器返回 HTTP 头中的 &quo ...
- C# UdpClient 设置超时时间
/********************************************************************** * C# UdpClient 设置超时时间 * 说明: ...
- TCP连接的超时时间
无论你用任何语言或者是网络库,你都可以设置网络操作的超时时间,特别是connect.read.write的超时时间. 你可以在代码中把超时时间设置任意大小值,但是connect方法会有一点特殊. co ...
- GRUB2配置详解:默认启动项,超时时间,隐藏引导菜单,配置文件详解,图形化配置
配置文件详解: /etc/default/grub # 设定默认启动项,推荐使用数字 GRUB_DEFAULT=0 # 注释掉下面这行将会显示引导菜单 #GRUB_HIDDEN_TIMEOUT=0 # ...
- config文件中可以配置查询超时时间
web.config配置数据库连接 第一种:获取连接字符串 首先要定义命名空间 system.configuration 1. string connstr= string constr = Con ...
随机推荐
- MySQL——一致性非锁定读(快照读)&MVCC
MySQL--一致性非锁定读(快照读) MySQL数据库中读分为一致性非锁定读.一致性锁定读 一致性非锁定读(快照读),普通的SELECT,通过多版本并发控制(MVCC)实现. 一致性锁定读(当前读) ...
- PyQt及PyCharm学习中遇到的问题
在PyQt及PyCharm学习过程中,老猿遇到了如下问题: 问题: 刚安装的PyCharm执行代码报"ModuleNotFoundError: No module named XXXX&qu ...
- PHP代码审计分段讲解(12)
28题 <!DOCTYPE html> <html> <head> <title>Web 350</title> <style typ ...
- Linux下netstat命令简单操作
netstat -t :TCP协议 -u :UDP协议 -l :监听 -r :路由 -n :显示IP地址和端口号 常用: netstat -tlun 查看本机监听的端口 netstat -an 查看本 ...
- SSH无密码登陆
http://blog.chinaunix.net/uid-26284395-id-2949145.html
- java视频流的断点续传功能
项目中需要实现浏览器中视频的拖动问题解决 /** * 视频文件的断点续传功能 * @param path 文件路径 * @param request request * @param response ...
- vue结合element-ui实现二级复选框checkbox
vue结合element-ui实现二级复选框checkbox 话不多说先上效果 交互:1.点击按钮全选,所有的checkbox全部选中:点击清空,所有的checkbox框都不选:点击确定获取选中的ch ...
- linux tar 压缩和解压缩
tar -c: 建立压缩档案-x:解压-t:查看内容-r:向压缩归档文件末尾追加文件-u:更新原压缩包中的文件 这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命令连用但只能用其中一个. 下面 ...
- python魔术方法总结
获取属性 __ getattr __(self, name) 定义当用户试图获取一个不存在的属性时的行为 __ getattribute __(self, name) 定义当该类的属性被访问时的行为 ...
- 【ubantu下安装python3.6】
Ubuntu16.04默认安装了Python2.7和3.5 请注意,系统自带的python千万不能卸载! 输入命令python