mirror of
https://github.com/nginx/nginx.git
synced 2024-12-04 13:59:00 +08:00
Upstream: keepalive flag.
This patch introduces r->upstream->keepalive flag, which is set by protocol handlers if connection to upstream is in good state and can be kept alive.
This commit is contained in:
parent
a746bab7c1
commit
2d6be3fe93
@ -1297,6 +1297,8 @@ ngx_http_upstream_reinit(ngx_http_request_t *r, ngx_http_upstream_t *u)
|
||||
return NGX_ERROR;
|
||||
}
|
||||
|
||||
u->keepalive = 0;
|
||||
|
||||
ngx_memzero(&u->headers_in, sizeof(ngx_http_upstream_headers_in_t));
|
||||
u->headers_in.content_length_n = -1;
|
||||
|
||||
@ -2006,6 +2008,11 @@ ngx_http_upstream_process_body_in_memory(ngx_http_request_t *r,
|
||||
}
|
||||
}
|
||||
|
||||
if (u->length == 0) {
|
||||
ngx_http_upstream_finalize_request(r, u, 0);
|
||||
return;
|
||||
}
|
||||
|
||||
if (ngx_handle_read_event(rev, 0) != NGX_OK) {
|
||||
ngx_http_upstream_finalize_request(r, u, NGX_ERROR);
|
||||
return;
|
||||
@ -2126,7 +2133,7 @@ ngx_http_upstream_send_response(ngx_http_request_t *r, ngx_http_upstream_t *u)
|
||||
return;
|
||||
}
|
||||
|
||||
if (u->peer.connection->read->ready) {
|
||||
if (u->peer.connection->read->ready || u->length == 0) {
|
||||
ngx_http_upstream_process_non_buffered_upstream(r, u);
|
||||
}
|
||||
}
|
||||
|
@ -308,6 +308,7 @@ struct ngx_http_upstream_s {
|
||||
#endif
|
||||
|
||||
unsigned buffering:1;
|
||||
unsigned keepalive:1;
|
||||
|
||||
unsigned request_sent:1;
|
||||
unsigned header_sent:1;
|
||||
|
Loading…
Reference in New Issue
Block a user