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