贴一下具体配置(超时部分的)。
Nginx:
http {
keepalive_timeout 600;
tcp_nodelay on;
fastcgi_connect_timeout 600;
fastcgi_send_timeout 600;
fastcgi_read_timeout 600;
}
PHP:
max_execution_time = 600
max_input_time = 60
memory_limit = 512M
PHP-FPM:
request_terminate_timeout = 0
request_slowlog_timeout = 0
slowlog = /var/log/slow.log
1
zm8m93Q1e5otOC69 2021 年 8 月 4 日 via Android
nginx ?
|
2
GG668v26Fd55CP5W 2021 年 8 月 4 日 via iPhone
看看 nginx 或者 apache 的日志
|
3
94 2021 年 8 月 4 日
如果是前端 Ajax 请求返回超时,那么你试试看用 postman 请求。
如果没有超时那就是前端部分设置了超时时间。 |
4
garlics 2021 年 8 月 4 日
有可能是框架里的其他地方设置了 max_execution_time,在一个地方加上 ini_set('max_execution_time', '0')试试
|
5
PUR4uF5Oq0z0YN9r 2021 年 8 月 4 日
换语言吧, php 中间套着 nginx 代理, 请求环节各种乱七八糟的配置, 稍有不慎就出问题
|
7
s609926202 OP @falcon05 nginx 日志显示的状态码为 499
|
8
s609926202 OP @beichenhpy 感觉不太是 ngxin 的原因,nginx 部分的超时也设置了,且远超 10s
|
9
suzic 2021 年 8 月 4 日 via Android
有用 apache 吗?这个问题我之前好像也遇到过
|
10
keepeye 2021 年 8 月 4 日
nginx 也要设置一下 fastcgi 的超时时间。
|
11
hfywy 2021 年 8 月 4 日
@s609926202 499 是“client has closed connection”,可能是客户端设置了超时时间
|
12
fatttt 2021 年 8 月 4 日 @sky3hao 我也觉得把 php 换掉比较好。 额外依赖的东西有点多。nginx,fpm 啥的,如果用 prometheus 监控还要给他写 exporter,多进程并发模型在容器化后 qps 一上来基本就凉凉。
|
14
guoer 2021 年 8 月 4 日
|
15
ElmerZhang 2021 年 8 月 4 日
502 是 nginx 与 php-fpm 建立连接成功后,php 没有正常返回就关闭了连接
有可能是 php 进程 segmentfault 了 php 进程池如果满了好像也会 502 另外还可以用 php -i 或者 phpinfo 找找哪个设置项上还有 10s 的超时设置 |
16
ElmerZhang 2021 年 8 月 4 日
这个超时肯定不是在 nginx 那边,如果是 nginx 超时的话会返回 504
|
17
PUR4uF5Oq0z0YN9r 2021 年 8 月 4 日
@liuxu 那你加油哦, 别换
|
18
Vectorst 2021 年 8 月 4 日
服务器是自己的吗?会不会是对方服务器对你做限制了
|
20
yogogo 2021 年 8 月 4 日
@liuxu 有些就是天生黑 PHP 不管有没有写过 PHP 。楼主 nginx 配置、PHP 框架、php.ini 都没写出来,那些就说 PHP 语言有问题的,你们确定写过 PHP ?
|
21
kidlj 2021 年 8 月 4 日
499 是客户端超时,就是访问接口的 app 或 curl 的超时时间。
|
22
thinkingbullet 2021 年 8 月 4 日
nginx 的 facgi 也有超时时间的设置
|
23
gidot 2021 年 8 月 4 日
看看慢查询日志,PHP 和 mysql 都看一下,特别是最开头的几条。有时 php 脚本服务器和数据库服务器直接网络不通畅时,也会 502,所以也要拍查一下 PHP 的错误日志,除了数据库之外,连接第三方服务超时也会 502 。
最后就是检查并发,比如 PHP 你只开了 60 个进程,如果这时候同时有 100 个请求,就会有 40 个在排队等待,也会造成超时。 |
24
akira 2021 年 8 月 4 日
大概率就是 nginx 那边 的超时强行关闭链接了
|
25
ivanfjz 2021 年 8 月 4 日
nginx 会把请求转发给 php-fpm, 然后等待 php-fpm 返回数据, 这个等待是有时间限制的, 你的服务器 nginx 配置限制了 10 秒. 你可以百度下 nginx fastcgi timeout 这 3 个关键词检索下, fastcgi_read_timeout(我猜修改这个配置就可以)
|
27
zhuzhibin 2021 年 8 月 4 日
进来就算骂的哈哈,动不动就换语言吧,还没点进来就想到了会有很多这种评论 233
|
28
liKeYunKeji 2021 年 8 月 4 日 via iPhone
天天有人黑 php,php 没有做错什么,只是时代变了而已。
|
29
way2create 2021 年 8 月 5 日
@Liang 看看他发帖回帖记录就明白了 有句话说的好 x 改不了 xx
|
30
GeorgeGalway 2021 年 8 月 13 日
@sky3hao 只有彩笔才会说换语言这种梗
|
31
zjttfs 2021 年 9 月 7 日
我也碰到这问题,什么都配置了, 10s 就断
|
32
s609926202 OP @zjttfs 我的是 VPN 影响的,可以参考一下
|