本文主要是介绍nginx 504 Gateway Time-out,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
环境:PHP7.1,NGINX,Mysql
问题描述:
本地写了一个需要执行比较长时间的脚本,放到了php-fpm里面跑。用一个链接调用起这个脚本。发现第一次调用的时候,需要等比较久的时间,但是如果在执行期间再次请求这个链接。第二个请求的链接会返回504。甚至,直接在脚本最开始的地方中断都还是报 504.
但是如果请求其他链接,可以正常请求。
nginx 返回码、、 504 Gateway Time-out
nginx 报错日志:
2018/06/13 09:53:48 [info] 530#0: *806 client timed out (60: Operation timed out) while waiting for request, client: 127.0.0.1, server: 0.0.0.0:80
问题的原因:
由于脚本执行时间较长。phpfpm 认为第二个请求与第一个请求一致。将第二个请求放到第一个的进程中去执行。导致这个问题。出现这个问题的解决办法,1️⃣尽量缩短脚本运行的时间,2️⃣同时将这种需要耗时的脚本以php-cli 方式运行~这种时候不会出现超时请款。
nginx常用超时时间~
client_header_timeout 指定等待client发送一个请求头的超时时间 NGINX 返回408
client_body_timeout 指定请求体返回超时时间 NGINX 返回408
keepalive_timeout HTTP 有一个 KeepAlive 模式,它告诉 webserver 在处理完一个请求后保持这个 TCP 连接的打开状态。若接收到来自客户端的其它请求,服务端会利用这个未被关闭的连接,而不需要再建立一个连接。KeepAlive 在一段时间内保持打开状态,它们会在这段时间内占用资源。占用过多就会影响性。若将它设置为 0,就禁止了 keepalive 连接。
lingering_timeout 可以理解为TCP连接关闭时的SO_LINGER延时设置,默认5s
resolver_timeout 域名解析超时,默认30s
send_timeout时间 发送数据至客户端超时, 默认60s, 如果连续的60s内客户端没有收到1个字节, 连接关闭
proxy_connect_timeout时间 定义与代理服务器建立连接的超时时间。应该指出的是,这个超时通常不能超过75秒。
proxy_read_timeout 定义从代理服务器读取响应的超时时间。超时指在两次连续的读操作之间设置,
proxy_send_timeout 设置向代理服务器发送请求的超时时间。超时只在两次连续写入操作之间设置
这篇关于nginx 504 Gateway Time-out的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!