需求:

一个php程序要跑一段时间,但是时间不确定。

问题:

当该php程序运行超过一段时间被强制断开连接。

PHP本身超时处理

在 php.ini 中,有一个参数 max_execution_time 可以设置 PHP 脚本的最大执行时间,但是,在 php-cgi(php-fpm) 中,该参数不会起效。真正能够控制 PHP 脚本最大执行时:

<value name="request_terminate_timeout">0s</value>

就是说如果是使用 mod_php5.so 的模式运行 max_execution_time 是会生效的,但是如果是php-fpm模式中运行时不生效的。

max_execution_time

计算的只是PHP脚本本身执行的时间,执行之外的时间都不会计算在内。哪些属于执行之外的时间呢?包含sleep、数据交互、socket交互等等。

request_terminate_timeout = 0  即为不受时间控制,永不超时

request_terminate_timeout引起的资源问题

request_terminate_timeout的值如果设置为0或者过长的时间,可能会引起file_get_contents的资源问题。

如果file_get_contents请求的远程资源如果反应过慢,file_get_contents就会一直卡在那里不会超时。我们知道php.ini 里面max_execution_time 可以设置 PHP 脚本的最大执行时间,但是,在 php-cgi(php-fpm) 中,该参数不会起效。真正能够控制 PHP 脚本最大执行时间的是 php-fpm.conf 配置文件中的request_terminate_timeout参数。

request_terminate_timeout默认值为 0 秒,也就是说,PHP 脚本会一直执行下去。这样,当所有的 php-cgi 进程都卡在 file_get_contents() 函数时,这台 Nginx+PHP 的 WebServer 已经无法再处理新的 PHP 请求了,Nginx 将给用户返回“502 Bad Gateway”。修改该参数,设置一个 PHP 脚本最大执行时间是必要的,但是,治标不治本。例如改成 30s,如果发生 file_get_contents() 获取网页内容较慢的情况,这就意味着 150 个 php-cgi 进程,每秒钟只能处理 5 个请求,WebServer 同样很难避免”502 Bad Gateway”。解决办法是request_terminate_timeout设置为10s或者一个合理的值,或者给file_get_contents加一个超时参数

如果常有请求超时,请打开php-fpm的慢日志,通过日志来确认评估超时时间。

Ngnix中的fastcgi 请求时间控制

fastcgi_connect_timeout

语法:fastcgi_connect_timeout time

默认值:fastcgi_connect_timeout 60

使用字段:http, server, location

指定同FastCGI服务器的连接超时时间,这个值不能超过75秒。

fastcgi_read_timeout

语法:fastcgi_read_timeout time

默认值:fastcgi_read_timeout 60

使用字段:http, server, location

前端FastCGI服务器的响应超时时间,如果有一些直到它们运行完才有输出的长时间运行的FastCGI进程,或者在错误日志中出现前端服务器响应超时错误,可能需要调整这个值。

fastcgi_send_timeout

语法:fastcgi_send_timeout time

默认值:fastcgi_send_timeout 60

使用字段:http, server, location

指令为上游服务器设置等待一个FastCGI进程的传送数据时间,如果有一些直到它们运行完才有输出的长时间运行的FastCGI进程,那么可以修改这个值,如果你在上有服务器的error log里面发现一些超时错误,那么可以恰当的增加这个值。

指令指定请求服务器的超时时间,指完成了2次握手的连接,而不是完整的连接,如果在这期间客户端没有进行数据传递,那么服务器将关闭这个连接。

在nginx+FastCGI 配置测试中

其中在request_terminate_timeout设置为永不超时的情况下,nginx中fastcgi_read_timeout 的设置时间将影响到最终的超时时间。

测试中,如果是php-fpm中的超时

将显示 502 Bad Gateway

<html>

<head><title>502 Bad Gateway</title></head>

<body bgcolor="white">

<center><h1>502 Bad Gateway</h1></center>

<hr><center>nginx</center>

</body>

</html>

如果是nginx中cgi配置超时

将显示 504 Gateway Time-out

<html>

<head><title>504 Gateway Time-out</title></head>

<body bgcolor="white">

<center><h1>504 Gateway Time-out</h1></center>

<hr><center>nginx</center>

</body>

</html>

转载于:https://blog.51cto.com/zhangxylinux/1543035

nginx+FastCGI到底是谁影响超时时间相关推荐

  1. nginx限制上传大小和超时时间设置说明/php限制上传大小

    现象说明: 在服务器上部署了一套后台环境,使用的是nginx反向代理tomcat架构,在后台里上传一个70M的视频文件,上传到一半就失效了! 原因是nginx配置里限制了上传文件的大小 client_ ...

  2. nginx依靠超时时间实现上游负载web服务器重启时不影响访问

    nginx依靠超时时间实现上游负载web服务器重启时不影响访问 本文未配置主从机集群,主从多台集群. nginx.conf(或者外联配置文件)中,位于http{}之内,样例如下: - upstream ...

  3. NGINX 配置超时时间

    一.啥时候用到 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 用来设置请求资源和服务器返回的时间,保证一个请求占用固定时间,超出后报504超时!这 ...

  4. nginx 上传 文件超时设置_nginx限制上传大小和超时时间设置说明/php限制上传大小...

    现象说明: 在服务器上部署了一套后台环境,使用的是nginx反向代理tomcat架构,在后台里上传一个70M的视频文件,上传到一半就失效了! 原因是nginx配置里限制了上传文件的大小 client_ ...

  5. nginx 超时时间_Linux从入门到放弃 Nginx

    1.nginx概念 nginx是一个高性能http和反向代理web服务器. 占有内存少.并发能力强. 最高支持50000并发数. 1.正向代理 在客户端(浏览器)配置代理服务器.通过代理服务器进行互联 ...

  6. nginx设置超时时间

    nginx设置超时时间 server模块下                 proxy_connect_timeout  360000s;#nginx跟后端服务器连接超时时间(代理连接超时)     ...

  7. nginx 超时时间_我眼中的 Nginx(四):是什么让你的 Nginx 服务退出这么慢?

    张超:又拍云系统开发高级工程师,负责又拍云 CDN 平台相关组件的更新及维护.Github ID: tokers,活跃于 OpenResty 社区和 Nginx 邮件列表等开源社区,专注于服务端技术的 ...

  8. php工具箱mysql停止进程_PHP进程卡死和MySQL超时时间的设置方法

    前言 最近线上一台服务器的nginx总是会有一部分请求(不是所有请求)报upstream timed out (110: Connection timed out) while connecting ...

  9. 同时设置超时时间_刚入职的小菜鸡,设错了RPC超时,搞了个线上事故

    上面这张监控图,对于服务端的研发同学来说再熟悉不过了.在日常的系统维护中,『服务超时』应该属于监控报警最多的一类问题. 尤其在微服务架构下,一次请求可能要经过一条很长的链路,跨多个服务调用后才能返回结 ...

最新文章

  1. JSON字符串 拼接与解析
  2. python matplotlib画折线图_python使用matplotlib绘制折线图教程
  3. 提防iostream使用中的一个“陷阱”
  4. 【数学建模】MATLAB应用实战系列(九十)-变异系数法应用案例(附MATLAB和Python代码)
  5. python通讯录管理程序的用户可行性_通讯录管理系统项目可行性分析
  6. 20180925-4 单元测试 两人结对
  7. python 开发板 i2s_[Craftor原创] I2S总线接口设计(Verilog)
  8. 同步方法中的锁对象_互斥锁与读写锁:如何使用锁完成Go程同步?
  9. iphone addressbook操作
  10. 导入工程后 报错 The import javax.faces cannot be resolved 解决办法
  11. scala中zip拉链的操作
  12. 苹果pns推送和唤醒
  13. FreeSwitch Originate API
  14. 逻辑回归算法深度思考-优点和缺点
  15. 防火墙的三种工作模式介绍(路由模式、透明模式(网桥)、混合模式)
  16. 解决ios的webview中上/下拉露出黑灰色背景问题
  17. 解决:SpringBoot中使用WebSocket传输数据,提示 1009|The decoded text message was too big for the output buffer and
  18. 【案例】携手捷普 :让流程立于云端,臻于至善
  19. Python的5大就业方向,薪资诱人前景好
  20. python做一个枪战游戏

热门文章

  1. LED数码管仿真显示程序
  2. HighLight selected features
  3. JS+Canvas的棋盘游戏和Java的动态结合
  4. Cflow使用具体解释
  5. PHP 语言结构(Language constructs)和函数的区别
  6. 软件开发的N种基础武器 - 最新清单
  7. expand yourself
  8. iphone-common-codes-ccteam源代码 CCGraphics.m
  9. Windows文件操作的直接函数调用
  10. 立下“去O”Flag的AWS,悄悄修炼了哪些内功?