nginx http keep alive 只能发100个请求!!

前几天在研究 http keepalive,使用pipeline的方式。结果发现server端只能接收到100个请求。必须断开连接后才能继续发送更多的请求。

问题…..问题出在哪里?

1. 路由和中间节点

2. nginx

3. web服务器

4. 程序写bug了

第一个“中间路由和节点”很好排除。只要把程序放在和nginx 同一台机器上就可以了。

第二个“nginx”,这个把nginx的log打开,看看收到多少个请求。
第三个”web服务器”,这个也好排除,只要把web服务器的log打开,打印一下就好了。

第四个那就是使用client访问时,用wireshark抓个包。看看第100个请求和101个请求到底有什么不同。

结果1,2,4都被排除了。只有nginx的问题。关键是没有做什么特殊设置。到底为什么只能收100个呢?扫了一下源代码,发现 keepalive_requests这个值被设置为了100,大于这个数值nginx就会发送RST包回来。和wireshark中看到的server端发送RST包的现象一致。然后改动了该值为1000,发现pipeline的请求就可以发送1000个了。

另外这个100值,不知道是nginx看了tomcat,还是tomcat抄袭了nginx。反正这个设置出奇的诡异。

  • 本文作者: 帐前卒
  • 本文链接: http://chillyc.info/2013/11580521/
  • 版权声明: 本博客所有文章除特别声明外,只能复制超链接地址,且必须注明出处!