mirror of https://github.com/openresty/openresty
bugfix: backported Maxim Dounin's patch to fix an issue in the ngx_gzip module: it did not clear r->connection->buffered when the pending data was already flushed out. this could hang ngx_lua's ngx.flush(true) call, for example.
parent
2d3ff6af97
commit
274b1b6778
@ -0,0 +1,42 @@
|
|||||||
|
|
||||||
|
# HG changeset patch
|
||||||
|
# User Maxim Dounin <mdounin@mdounin.ru>
|
||||||
|
# Date 1374749732 -14400
|
||||||
|
# Node ID 84155a389bcc249138e18546134cfbff1931013b
|
||||||
|
# Parent 355779f81491a78f3fe79e4a1eb5036c3882b441
|
||||||
|
Gzip: clearing of c->buffered if all data are flushed.
|
||||||
|
|
||||||
|
This allows to finalize unfinished responses while still sending as
|
||||||
|
much data as available.
|
||||||
|
|
||||||
|
diff -r 355779f81491 -r 84155a389bcc src/http/modules/ngx_http_gzip_filter_module.c
|
||||||
|
--- a/src/http/modules/ngx_http_gzip_filter_module.c Thu Jul 25 14:55:09 2013 +0400
|
||||||
|
+++ b/src/http/modules/ngx_http_gzip_filter_module.c Thu Jul 25 14:55:32 2013 +0400
|
||||||
|
@@ -368,6 +368,8 @@
|
||||||
|
if (ngx_chain_add_copy(r->pool, &ctx->in, in) != NGX_OK) {
|
||||||
|
goto failed;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ r->connection->buffered |= NGX_HTTP_GZIP_BUFFERED;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ctx->nomem) {
|
||||||
|
@@ -620,8 +622,6 @@
|
||||||
|
return NGX_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
- r->connection->buffered |= NGX_HTTP_GZIP_BUFFERED;
|
||||||
|
-
|
||||||
|
ctx->last_out = &ctx->out;
|
||||||
|
ctx->crc32 = crc32(0L, Z_NULL, 0);
|
||||||
|
ctx->flush = Z_NO_FLUSH;
|
||||||
|
@@ -854,6 +854,8 @@
|
||||||
|
*ctx->last_out = cl;
|
||||||
|
ctx->last_out = &cl->next;
|
||||||
|
|
||||||
|
+ r->connection->buffered &= ~NGX_HTTP_GZIP_BUFFERED;
|
||||||
|
+
|
||||||
|
return NGX_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue