0
Fork 0
mirror of https://github.com/caddyserver/caddy.git synced 2025-01-13 22:51:08 -05:00

Revert "reverseproxy: Separate ignore_client_gone option"

This reverts commit 8c9e87d0a6.
This commit is contained in:
Matthew Holt 2024-11-12 14:36:25 -07:00
parent 8c9e87d0a6
commit 04a58a9356

View file

@ -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()})
} }