mirror of
https://github.com/caddyserver/caddy.git
synced 2024-12-30 22:34:15 -05:00
reverseproxy: Fix overwriting of max_idle_conns_per_host (closes #4201)
Also split the Caddyfile subdirective keepalive_idle_conns into two properties so the conns and conns_per_host can be set separately. This is technically a breaking change, but probably anyone who this breaks already had a broken config anyway, and silently fixing it won't help them fix their configs.
This commit is contained in:
parent
6d25261c22
commit
7c68809f4e
3 changed files with 16 additions and 18 deletions
|
@ -978,6 +978,18 @@ func (h *HTTPTransport) UnmarshalCaddyfile(d *caddyfile.Dispenser) error {
|
||||||
h.KeepAlive = new(KeepAlive)
|
h.KeepAlive = new(KeepAlive)
|
||||||
}
|
}
|
||||||
h.KeepAlive.MaxIdleConns = num
|
h.KeepAlive.MaxIdleConns = num
|
||||||
|
|
||||||
|
case "keepalive_idle_conns_per_host":
|
||||||
|
if !d.NextArg() {
|
||||||
|
return d.ArgErr()
|
||||||
|
}
|
||||||
|
num, err := strconv.Atoi(d.Val())
|
||||||
|
if err != nil {
|
||||||
|
return d.Errf("bad integer value '%s': %v", d.Val(), err)
|
||||||
|
}
|
||||||
|
if h.KeepAlive == nil {
|
||||||
|
h.KeepAlive = new(KeepAlive)
|
||||||
|
}
|
||||||
h.KeepAlive.MaxIdleConnsPerHost = num
|
h.KeepAlive.MaxIdleConnsPerHost = num
|
||||||
|
|
||||||
case "versions":
|
case "versions":
|
||||||
|
@ -1004,16 +1016,6 @@ func (h *HTTPTransport) UnmarshalCaddyfile(d *caddyfile.Dispenser) error {
|
||||||
}
|
}
|
||||||
h.MaxConnsPerHost = num
|
h.MaxConnsPerHost = num
|
||||||
|
|
||||||
case "max_idle_conns_per_host":
|
|
||||||
if !d.NextArg() {
|
|
||||||
return d.ArgErr()
|
|
||||||
}
|
|
||||||
num, err := strconv.Atoi(d.Val())
|
|
||||||
if err != nil {
|
|
||||||
return d.Errf("bad integer value '%s': %v", d.Val(), err)
|
|
||||||
}
|
|
||||||
h.MaxIdleConnsPerHost = num
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return d.Errf("unrecognized subdirective %s", d.Val())
|
return d.Errf("unrecognized subdirective %s", d.Val())
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,9 +62,6 @@ type HTTPTransport struct {
|
||||||
// Maximum number of connections per host. Default: 0 (no limit)
|
// Maximum number of connections per host. Default: 0 (no limit)
|
||||||
MaxConnsPerHost int `json:"max_conns_per_host,omitempty"`
|
MaxConnsPerHost int `json:"max_conns_per_host,omitempty"`
|
||||||
|
|
||||||
// Maximum number of idle connections per host. Default: 0 (uses Go's default of 2)
|
|
||||||
MaxIdleConnsPerHost int `json:"max_idle_conns_per_host,omitempty"`
|
|
||||||
|
|
||||||
// How long to wait before timing out trying to connect to
|
// How long to wait before timing out trying to connect to
|
||||||
// an upstream.
|
// an upstream.
|
||||||
DialTimeout caddy.Duration `json:"dial_timeout,omitempty"`
|
DialTimeout caddy.Duration `json:"dial_timeout,omitempty"`
|
||||||
|
@ -197,7 +194,6 @@ func (h *HTTPTransport) NewTransport(ctx caddy.Context) (*http.Transport, error)
|
||||||
return conn, nil
|
return conn, nil
|
||||||
},
|
},
|
||||||
MaxConnsPerHost: h.MaxConnsPerHost,
|
MaxConnsPerHost: h.MaxConnsPerHost,
|
||||||
MaxIdleConnsPerHost: h.MaxIdleConnsPerHost,
|
|
||||||
ResponseHeaderTimeout: time.Duration(h.ResponseHeaderTimeout),
|
ResponseHeaderTimeout: time.Duration(h.ResponseHeaderTimeout),
|
||||||
ExpectContinueTimeout: time.Duration(h.ExpectContinueTimeout),
|
ExpectContinueTimeout: time.Duration(h.ExpectContinueTimeout),
|
||||||
MaxResponseHeaderBytes: h.MaxResponseHeaderSize,
|
MaxResponseHeaderBytes: h.MaxResponseHeaderSize,
|
||||||
|
@ -412,13 +408,13 @@ type KeepAlive struct {
|
||||||
// How often to probe for liveness.
|
// How often to probe for liveness.
|
||||||
ProbeInterval caddy.Duration `json:"probe_interval,omitempty"`
|
ProbeInterval caddy.Duration `json:"probe_interval,omitempty"`
|
||||||
|
|
||||||
// Maximum number of idle connections.
|
// Maximum number of idle connections. Default: 0, which means no limit.
|
||||||
MaxIdleConns int `json:"max_idle_conns,omitempty"`
|
MaxIdleConns int `json:"max_idle_conns,omitempty"`
|
||||||
|
|
||||||
// Maximum number of idle connections per upstream host.
|
// Maximum number of idle connections per host. Default: 0, which uses Go's default of 2.
|
||||||
MaxIdleConnsPerHost int `json:"max_idle_conns_per_host,omitempty"`
|
MaxIdleConnsPerHost int `json:"max_idle_conns_per_host,omitempty"`
|
||||||
|
|
||||||
// How long connections should be kept alive when idle.
|
// How long connections should be kept alive when idle. Default: 0, which means no timeout.
|
||||||
IdleConnTimeout caddy.Duration `json:"idle_timeout,omitempty"`
|
IdleConnTimeout caddy.Duration `json:"idle_timeout,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -204,7 +204,7 @@ func (h *Handler) Provision(ctx caddy.Context) error {
|
||||||
KeepAlive: &KeepAlive{
|
KeepAlive: &KeepAlive{
|
||||||
ProbeInterval: caddy.Duration(30 * time.Second),
|
ProbeInterval: caddy.Duration(30 * time.Second),
|
||||||
IdleConnTimeout: caddy.Duration(2 * time.Minute),
|
IdleConnTimeout: caddy.Duration(2 * time.Minute),
|
||||||
MaxIdleConnsPerHost: 32,
|
MaxIdleConnsPerHost: 32, // seems about optimal, see #2805
|
||||||
},
|
},
|
||||||
DialTimeout: caddy.Duration(10 * time.Second),
|
DialTimeout: caddy.Duration(10 * time.Second),
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue