详解Nginx服务器中配置超时时间的方法
一、啥时候用到
用来设置请求资源和服务器返回的时间,保证一个请求占用固定时间,超出后报504超时!这样可以保证一个请求占用过长时间。
二、主要参数
使用nginx服务器如果遇到timeou情况时可以如下设置参数,使用fastcgi:
fastcgi_connect_timeout75; 链接
fastcgi_read_timeout600; 读取
fastcgi_send_timeout600; 发请求
这两个选项.
fastcgi_read_timeout是指fastcgi进程向nginx进程发送response的整个过程的超时时间
fastcgi_send_timeout是指nginx进程向fastcgi进程发送request的整个过程的超时时间
这两个选项默认都是秒(s),可以手动指定为分钟(m),小时(h)等
三、其他常用参数以及参数说明
keepalive_timeout 600; 连接超时时间,1分钟,具体时间可以根据请求(例如后台导入)需要的时间来设置
proxy_connect_timeout600; 1分钟
proxy_read_timeout600; 1分钟
nginx超时配置参数说明:
keepalive_timeout
语法keepalive_timeouttimeout[header_timeout]
默认值75s
上下文httpserverlocation
说明第一个参数指定了与client的keep-alive连接超时时间。服务器将会在这个时间后关闭连接。可选的第二个参数指定了在响应头Keep-Alive:timeout=time中的time值。这个头能够让一些浏览器主动关闭连接,这样服务器就不必要去关闭连接了。没有这个参数,nginx不会发送Keep-Alive响应头(尽管并不是由这个头来决定连接是否“keep-alive”)
两个参数的值可并不相同
注意不同浏览器怎么处理“keep-alive”头
MSIE和Opera忽略掉"Keep-Alive:timeout=<N>"header.
MSIE保持连接大约60-65秒,然后发送TCPRST
Opera永久保持长连接
MozillakeepstheconnectionaliveforNplusabout1-10seconds.
Konqueror保持长连接N秒
proxy_connect_timeout
语法proxy_connect_timeouttime
默认值60s
上下文httpserverlocation
说明该指令设置与upstreamserver的连接超时时间,有必要记住,这个超时不能超过75秒。
这个不是等待后端返回页面的时间,那是由proxy_read_timeout声明的。如果你的upstream服务器起来了,但是hanging住了(例如,没有足够的线程处理请求,所以把你的请求放到请求池里稍后处理),那么这个声明是没有用的,由于与upstream服务器的连接已经建立了。
proxy_read_timeout
语法proxy_read_timeouttime
默认值60s
上下文httpserverlocation
说明该指令设置与代理服务器的读超时时间。它决定了nginx会等待多长时间来获得请求的响应。这个时间不是获得整个response的时间,而是两次reading操作的时间。
client_header_timeout
语法client_header_timeouttime
默认值60s
上下文httpserver
说明指定等待client发送一个请求头的超时时间(例如:GET/HTTP/1.1).仅当在一次read中,没有收到请求头,才会算成超时。如果在超时时间内,client没发送任何东西,nginx返回HTTP状态码408(“Requesttimedout”)
client_body_timeout
语法client_body_timeouttime
默认值60s
上下文httpserverlocation
说明该指令设置请求体(requestbody)的读超时时间。仅当在一次readstep中,没有得到请求体,就会设为超时。超时后,nginx返回HTTP状态码408(“Requesttimedout”)
lingering_timeout
语法lingering_timeouttime
默认值5s
上下文httpserverlocation
说明lingering_close生效后,在关闭连接前,会检测是否有用户发送的数据到达服务器,如果超过lingering_timeout时间后还没有数据可读,就直接关闭连接;否则,必须在读取完连接缓冲区上的数据并丢弃掉后才会关闭连接。
resolver_timeout
语法resolver_timeouttime
默认值30s
上下文httpserverlocation
说明该指令设置DNS解析超时时间
proxy_send_timeout
语法proxy_send_timeouttime
默认值60s
上下文httpserverlocation
说明这个指定设置了发送请求给upstream服务器的超时时间。超时设置不是为了整个发送期间,而是在两次write操作期间。如果超时后,upstream没有收到新的数据,nginx会关闭连接
proxy_upstream_fail_timeout(fail_timeout)
语法serveraddress[fail_timeout=30s]
默认值10s
上下文upstream
说明Upstream模块下server指令的参数,设置了某一个upstream后端失败了指定次数(max_fails)后,该后端不可操作的时间,默认为10秒
四、实例
这里来看一个把Nginx的超时时间上调的例子。
看看时间是否符合要求,在nginx.config里面的三个参数:
- fastcgi_connect_timeout300;
- fastcgi_send_timeout300;
- fastcgi_read_timeout300;
以上的单位是秒。
如果使用了Nginx的代理,可以在块里加上:
proxy_connect_timeout300s; proxy_send_timeout300s; proxy_read_timeout300s;
变成:
location/foo{ proxy_passhttp://xxx.xxx.xxx.xxx:8080/foo; proxy_set_headerHost$host; proxy_set_headerX-Real-IP$remote_addr; proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for; proxy_connect_timeout300s; proxy_send_timeout300s; proxy_read_timeout300s; access_log/var/log/nginx/access.foo.logmain; error_log/var/log/nginx/error.foo.log; }