nginx中开启keepalive后应答反而为close的原因

nginx中开启keepalive后应答反而为close的原因

  • 现象和原因

    采用nginx作为服务器向用户提供查询服务,由于业务原因,只需要应答header就可以,不需要响应body。
    在header_filter_by_luangx.header["Content-Length"] = nil, 在body_filter_by_lua中设置ngx.arg[1] = nil
    通过以上两个简单的lua语句的设置,功能就已经实现。

    此时请求内容,应答体就是空,响应头里也没有content-length字段。
    可是。。。
    nginx.conf中明明配置了 keepalive_timeout 60
    发起携带keep-alive的请求,应答依然是close呢?

nginx中开启keepalive后应答反而为close的原因

查看nginx源码,在chunked filter中发现如下代码

nginx中开启keepalive后应答反而为close的原因

nginx.conf中配置了chunked_transfer_encoding off
这样的话, 就解释通了。 header_filter中设置content-length = nil ,就是让r->headers_out.content_length_n = -1 , 同时又关闭了chuanked的功能,所以chunked_filter把keepalive设置为0了, 所以导致connection是close的。

在http1.1及之后版本。如果是keep alive,则content-length和chunk必然是二选一。

这边文章有说明可参考

http://blog.****.net/yankai0219/article/details/8269922