概要

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进程状态,其中包括是否已超时

规则:

  1. 开启reqeust_terminate_timeout的情况下:heartbeat = reqeust_terminate_timeout/1000*3
  2. 未开启request_terminate_timeout的情况下:heartbeat = request_slowlog_timeout/1000*3或者为0
  3. request_terminate_timeout >= request_slowlog_timeout

ps:此处如果由于request_terminate_timeout导致超时的发生的话,会直接kille掉worker进程,之后内核挥手client_socket,nginx返回502错误给客户端

[php]配置文件中的超时时间的更多相关文章

  1. 在使用jjwt时在配置文件中设置过期时间,取到的结果为0的原因

    在设置了过期时间后感觉没有起作用,打印日志查看了下为0,因为生成token的文件在一个公共模块中,而过期时间设置在服务模块 中的配置文件中. 原因是:没有为设置getter和setter方法 来自为知 ...

  2. nginx中的超时配置

    nginx.conf配置文件中timeout超时时间设置 client_header_timeout 语法 client_header_timeout time默认值 60s上下文 http serv ...

  3. 【Spring Cloud 源码解读】之 【如何配置好OpenFeign的各种超时时间!】

    关于Feign的超时详解: 在Spring Cloud微服务架构中,大部分公司都是利用Open Feign进行服务间的调用,而比较简单的业务使用默认配置是不会有多大问题的,但是如果是业务比较复杂,服务 ...

  4. 设置linux中tcp默认的20秒connect超时时间(转)

    无论你用任何语言或者是网络库,你都可以设置网络操作的超时时间,特别是connect.read.write的超时时间. 你可以在代码中把超时时间设置任意大小值,但是connect方法会有一点特殊. co ...

  5. 设置php下载文件的超时时间

    使用curl 可以使用curl自己实现一个curl_file_get_contents函数 //CURLOPT_FOLLOWLOCATION TRUE 时将会根据服务器返回 HTTP 头中的 &quo ...

  6. C# UdpClient 设置超时时间

    /********************************************************************** * C# UdpClient 设置超时时间 * 说明: ...

  7. TCP连接的超时时间

    无论你用任何语言或者是网络库,你都可以设置网络操作的超时时间,特别是connect.read.write的超时时间. 你可以在代码中把超时时间设置任意大小值,但是connect方法会有一点特殊. co ...

  8. GRUB2配置详解:默认启动项,超时时间,隐藏引导菜单,配置文件详解,图形化配置

    配置文件详解: /etc/default/grub # 设定默认启动项,推荐使用数字 GRUB_DEFAULT=0 # 注释掉下面这行将会显示引导菜单 #GRUB_HIDDEN_TIMEOUT=0 # ...

  9. config文件中可以配置查询超时时间

    web.config配置数据库连接 第一种:获取连接字符串 首先要定义命名空间 system.configuration 1.  string connstr= string constr = Con ...

随机推荐

  1. xargs--冬天里的一丝暖意

    本文为博客园作者所写: 一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 你有批量kill作业吗?有因为删除文件夹的内容太多而报错吗?-bash: /bin/rm: ...

  2. vue回调接口

    1.微博回调接口 1.1oauth/urls.py 中添加路由 urlpatterns = [ path('weibo/callback/', views.OauthWeiboCallback.as_ ...

  3. java备份Oracle数据库表

    <html><head><title>数据备份</title><meta name="decorator" content=& ...

  4. 第12.3节 Python math模块导览

    math 模块提供对浮点数学的底层C库函数的访问,常用的成员包括: math.ceil(x):返回 x 的上限,即大于或者等于 x 的最小整数 math.floor(x):返回 x 的向下取整,小于或 ...

  5. [GKCTF2020]CheckIN 注意了解多方面的东西

    打开之后是这样的,没有发现反序列化函数,但是发现有一个@eval,想到了一句话,这是用base64进行传参首先传参phpinfo();看看,需要经过base64编码 http://e0cc90ac-d ...

  6. Shell命令和流程控制[linux常用命令的使用]

    在shell脚本中使用三类命令: unix命令 概念:管道.重定向.backtick 流程控制 1 unix命令 echo "some text":在屏幕上输出信息 ls:文件列表 ...

  7. 个人项目作业--WC的实现

     GitHub项目地址 https://github.com/1721819634/WC 1.Word Count 项目要求: wc.exe 是一个常见的工具,它能统计文本文件的字符数.单词数和行数. ...

  8. vue 编程式导航

    // 命名的路由(这里的name为路由中定义的name名称) this.$router.push({ name: 'user', params: { userId: '123' }}) // 带查询参 ...

  9. this作为构造函数时注意点

    在 JS 中,为了实现类,我们需要定义一些构造函数,在调用一个构造函数的时候加上 new 这个关键字: function Person(name) { this.name = name; consol ...

  10. P7077 函数调用

    我好蠢啊... 考试的时候不会写,现在看了这么多篇题解还是似懂非懂,所以决定写一下草稿... 草稿 和 题解 就是首先,题目保证了函数不会间接的调用其本身,所以可以直接知道这是一个 \(\text{D ...