mirror of
https://github.com/caddyserver/caddy.git
synced 2024-12-30 22:34:15 -05:00
Revert "reverseproxy: Separate ignore_client_gone option"
This reverts commit 8c9e87d0a6
.
This commit is contained in:
parent
8c9e87d0a6
commit
04a58a9356
1 changed files with 11 additions and 17 deletions
|
@ -106,15 +106,12 @@ type Handler struct {
|
||||||
// response is recognized as a streaming response, or if its
|
// response is recognized as a streaming response, or if its
|
||||||
// content length is -1; for such responses, writes are flushed
|
// content length is -1; for such responses, writes are flushed
|
||||||
// to the client immediately.
|
// to the client immediately.
|
||||||
FlushInterval caddy.Duration `json:"flush_interval,omitempty"`
|
//
|
||||||
|
|
||||||
// Normally, a request will be canceled if the client disconnects
|
// Normally, a request will be canceled if the client disconnects
|
||||||
// before the response is received from the backend. If enabled,
|
// before the response is received from the backend. If explicitly
|
||||||
// client disconnection will be ignored and the request with the
|
// set to -1, client disconnection will be ignored and the request
|
||||||
// backend will carry on until the backend terminates it. This
|
// will be completed to help facilitate low-latency streaming.
|
||||||
// can help facilitate low-latency streaming. See #4922 and #4952.
|
FlushInterval caddy.Duration `json:"flush_interval,omitempty"`
|
||||||
// EXPERIMENTAL: Will likely be removed in the future.
|
|
||||||
IgnoreClientGone bool `json:"ignore_client_gone,omitempty"`
|
|
||||||
|
|
||||||
// A list of IP ranges (supports CIDR notation) from which
|
// A list of IP ranges (supports CIDR notation) from which
|
||||||
// X-Forwarded-* header values should be trusted. By default,
|
// X-Forwarded-* header values should be trusted. By default,
|
||||||
|
@ -776,15 +773,12 @@ func (h *Handler) reverseProxy(rw http.ResponseWriter, req *http.Request, origRe
|
||||||
}
|
}
|
||||||
req = req.WithContext(httptrace.WithClientTrace(req.Context(), trace))
|
req = req.WithContext(httptrace.WithClientTrace(req.Context(), trace))
|
||||||
|
|
||||||
// if enabled, don't let the transport cancel the request if the client disconnects:
|
// if FlushInterval is explicitly configured to -1 (i.e. flush continuously to achieve
|
||||||
// user probably wants us to finish sending the data to the upstream regardless,
|
// low-latency streaming), don't let the transport cancel the request if the client
|
||||||
// and we should expect client disconnection in low-latency streaming scenarios
|
// disconnects: user probably wants us to finish sending the data to the upstream
|
||||||
// (see issue #4922)
|
// regardless, and we should expect client disconnection in low-latency streaming
|
||||||
// TODO: An ideal solution, if the client disconnects before the backend is done
|
// scenarios (see issue #4922)
|
||||||
// receiving data from the proxy, is to wait until the baxkend is done receiving
|
if h.FlushInterval == -1 {
|
||||||
// the data and then close the connection with the backend, rather than an explicit
|
|
||||||
// option to always leave it open...
|
|
||||||
if h.IgnoreClientGone {
|
|
||||||
req = req.WithContext(ignoreClientGoneContext{req.Context()})
|
req = req.WithContext(ignoreClientGoneContext{req.Context()})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue