mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-14 06:46:27 +03:00
Add min_success_ratio
WIP
This commit is contained in:
parent
c4b934f232
commit
c8b8c3a7b2
2 changed files with 22 additions and 0 deletions
|
@ -78,6 +78,7 @@ func parseCaddyfile(h httpcaddyfile.Helper) (caddyhttp.MiddlewareHandler, error)
|
||||||
// fail_duration <duration>
|
// fail_duration <duration>
|
||||||
// max_fails <num>
|
// max_fails <num>
|
||||||
// success_duration <duration>
|
// success_duration <duration>
|
||||||
|
// min_success_ratio <ratio>
|
||||||
// unhealthy_status <status>
|
// unhealthy_status <status>
|
||||||
// unhealthy_latency <duration>
|
// unhealthy_latency <duration>
|
||||||
// unhealthy_request_count <num>
|
// unhealthy_request_count <num>
|
||||||
|
@ -439,6 +440,22 @@ func (h *Handler) UnmarshalCaddyfile(d *caddyfile.Dispenser) error {
|
||||||
}
|
}
|
||||||
h.HealthChecks.Passive.SuccessDuration = caddy.Duration(dur)
|
h.HealthChecks.Passive.SuccessDuration = caddy.Duration(dur)
|
||||||
|
|
||||||
|
case "min_success_ratio":
|
||||||
|
if !d.NextArg() {
|
||||||
|
return d.ArgErr()
|
||||||
|
}
|
||||||
|
if h.HealthChecks == nil {
|
||||||
|
h.HealthChecks = new(HealthChecks)
|
||||||
|
}
|
||||||
|
if h.HealthChecks.Passive == nil {
|
||||||
|
h.HealthChecks.Passive = new(PassiveHealthChecks)
|
||||||
|
}
|
||||||
|
ratio, err := caddyhttp.ParseRatio(d.Val())
|
||||||
|
if err != nil {
|
||||||
|
return d.Errf("bad ratio value '%s': %v", d.Val(), err)
|
||||||
|
}
|
||||||
|
h.HealthChecks.Passive.MinSuccessRatio = ratio
|
||||||
|
|
||||||
case "fail_duration":
|
case "fail_duration":
|
||||||
if !d.NextArg() {
|
if !d.NextArg() {
|
||||||
return d.ArgErr()
|
return d.ArgErr()
|
||||||
|
|
|
@ -122,6 +122,11 @@ type PassiveHealthChecks struct {
|
||||||
// How long to remember a successful request to a backend. Default is 0.
|
// How long to remember a successful request to a backend. Default is 0.
|
||||||
SuccessDuration caddy.Duration `json:"success_duration,omitempty"`
|
SuccessDuration caddy.Duration `json:"success_duration,omitempty"`
|
||||||
|
|
||||||
|
// The minimum ratio of successful to failed requests necessary to
|
||||||
|
// consider a backend as healthy. Both fail and success durations
|
||||||
|
// must be configured for those stats to be counted. Default is 0 (no ratio).
|
||||||
|
MinSuccessRatio caddyhttp.Ratio `json:"min_success_ratio,omitempty"`
|
||||||
|
|
||||||
// Limits the number of simultaneous requests to a backend by
|
// Limits the number of simultaneous requests to a backend by
|
||||||
// marking the backend as "down" if it has this many concurrent
|
// marking the backend as "down" if it has this many concurrent
|
||||||
// requests or more.
|
// requests or more.
|
||||||
|
|
Loading…
Reference in a new issue