nginx+FastCGI到底是谁影响超时时间
需求:
一个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到底是谁影响超时时间相关推荐
- nginx限制上传大小和超时时间设置说明/php限制上传大小
现象说明: 在服务器上部署了一套后台环境,使用的是nginx反向代理tomcat架构,在后台里上传一个70M的视频文件,上传到一半就失效了! 原因是nginx配置里限制了上传文件的大小 client_ ...
- nginx依靠超时时间实现上游负载web服务器重启时不影响访问
nginx依靠超时时间实现上游负载web服务器重启时不影响访问 本文未配置主从机集群,主从多台集群. nginx.conf(或者外联配置文件)中,位于http{}之内,样例如下: - upstream ...
- NGINX 配置超时时间
一.啥时候用到 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 用来设置请求资源和服务器返回的时间,保证一个请求占用固定时间,超出后报504超时!这 ...
- nginx 上传 文件超时设置_nginx限制上传大小和超时时间设置说明/php限制上传大小...
现象说明: 在服务器上部署了一套后台环境,使用的是nginx反向代理tomcat架构,在后台里上传一个70M的视频文件,上传到一半就失效了! 原因是nginx配置里限制了上传文件的大小 client_ ...
- nginx 超时时间_Linux从入门到放弃 Nginx
1.nginx概念 nginx是一个高性能http和反向代理web服务器. 占有内存少.并发能力强. 最高支持50000并发数. 1.正向代理 在客户端(浏览器)配置代理服务器.通过代理服务器进行互联 ...
- nginx设置超时时间
nginx设置超时时间 server模块下 proxy_connect_timeout 360000s;#nginx跟后端服务器连接超时时间(代理连接超时) ...
- nginx 超时时间_我眼中的 Nginx(四):是什么让你的 Nginx 服务退出这么慢?
张超:又拍云系统开发高级工程师,负责又拍云 CDN 平台相关组件的更新及维护.Github ID: tokers,活跃于 OpenResty 社区和 Nginx 邮件列表等开源社区,专注于服务端技术的 ...
- php工具箱mysql停止进程_PHP进程卡死和MySQL超时时间的设置方法
前言 最近线上一台服务器的nginx总是会有一部分请求(不是所有请求)报upstream timed out (110: Connection timed out) while connecting ...
- 同时设置超时时间_刚入职的小菜鸡,设错了RPC超时,搞了个线上事故
上面这张监控图,对于服务端的研发同学来说再熟悉不过了.在日常的系统维护中,『服务超时』应该属于监控报警最多的一类问题. 尤其在微服务架构下,一次请求可能要经过一条很长的链路,跨多个服务调用后才能返回结 ...
最新文章
- JSON字符串 拼接与解析
- python matplotlib画折线图_python使用matplotlib绘制折线图教程
- 提防iostream使用中的一个“陷阱”
- 【数学建模】MATLAB应用实战系列(九十)-变异系数法应用案例(附MATLAB和Python代码)
- python通讯录管理程序的用户可行性_通讯录管理系统项目可行性分析
- 20180925-4 单元测试 两人结对
- python 开发板 i2s_[Craftor原创] I2S总线接口设计(Verilog)
- 同步方法中的锁对象_互斥锁与读写锁:如何使用锁完成Go程同步?
- iphone addressbook操作
- 导入工程后 报错 The import javax.faces cannot be resolved 解决办法
- scala中zip拉链的操作
- 苹果pns推送和唤醒
- FreeSwitch Originate API
- 逻辑回归算法深度思考-优点和缺点
- 防火墙的三种工作模式介绍(路由模式、透明模式(网桥)、混合模式)
- 解决ios的webview中上/下拉露出黑灰色背景问题
- 解决:SpringBoot中使用WebSocket传输数据,提示 1009|The decoded text message was too big for the output buffer and
- 【案例】携手捷普 :让流程立于云端,臻于至善
- Python的5大就业方向,薪资诱人前景好
- python做一个枪战游戏