nginx连接后端服务时,使用upstream的方式,并且设置keepalive可以建立长连接,减少创建连接的消耗,提升效率。
但是,nginx默认采用http1.0协议,如果后端没有返回Connection:keepalive的header,设置的长连接是不生效的,大并发下会出现大量time_wait的连接。
两种解决方案:
1、后台服务在response header中加Connetion:keepalive
2、在nginx配置中显示指明http1.1协议(默认长连接),并且设置header Connnction=""
location ~ /XXX {
....
proxy_http_version 1.1;
proxy_set_header Connection "";
}
(很明显方案2成本更低)
详情见
http://nginx.org/cn/docs/http/ngx_http_upstream_module.html#keepalive
注:可以通过以下方法查看是否是长连接:
1、抓包,生成文件data.cap
tcpdump tcp -i lo -t -s 0 -c 10000 and port 9090 -w data.cap
2、用wireshark打开生成的data.cap
在一条数据上右击,点击“follow tcp stream”
a) 没有长连接的情况,每个连接只处理一条请求,然后关闭
b) 使用长连接的情况,每个连接处理多条请求