diff options
| author | Maxim Dounin <mdounin@mdounin.ru> | 2018-07-02 19:03:04 +0300 |
|---|---|---|
| committer | Maxim Dounin <mdounin@mdounin.ru> | 2018-07-02 19:03:04 +0300 |
| commit | 69fc41c9b5fc07084ff3870e2edeb9cef7f09f97 (patch) | |
| tree | 680f8163fa394c22078eefbbfbf558da1284552f /src/http/modules/ngx_http_grpc_module.c | |
| parent | a60bdcd8236919ced645115025d5cadaab295463 (diff) | |
| download | nginx-69fc41c9b5fc07084ff3870e2edeb9cef7f09f97.tar.gz nginx-69fc41c9b5fc07084ff3870e2edeb9cef7f09f97.tar.bz2 | |
Upstream: fixed tcp_nopush with gRPC.
With gRPC it is possible that a request sending is blocked due to flow
control. Moreover, further sending might be only allowed once the
backend sees all the data we've already sent. With such a backend
it is required to clear the TCP_NOPUSH socket option to make sure all
the data we've sent are actually delivered to the backend.
As such, we now clear TCP_NOPUSH in ngx_http_upstream_send_request()
also on NGX_AGAIN if c->write->ready is set. This fixes a test (which
waits for all the 64k bytes as per initial window before allowing more
bytes) with sendfile enabled when the body was written to a file
in a different context.
Diffstat (limited to 'src/http/modules/ngx_http_grpc_module.c')
0 files changed, 0 insertions, 0 deletions
