
贴一下具体配置(超时部分的)。
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 就断 |