go-watchdog/watermarks.go

42 lines
1.3 KiB
Go
Raw Normal View History

2020-12-02 00:03:20 +00:00
package watchdog
// NewWatermarkPolicy creates a watchdog policy that schedules GC at concrete
// watermarks. When queried, it will determine the next trigger point based
// on the current utilisation. If the last watermark is surpassed,
// the policy will request immediate GC.
func NewWatermarkPolicy(watermarks ...float64) PolicyCtor {
return func(limit uint64) (Policy, error) {
p := new(watermarkPolicy)
p.limit = limit
p.thresholds = make([]uint64, 0, len(watermarks))
for _, m := range watermarks {
p.thresholds = append(p.thresholds, uint64(float64(limit)*m))
2020-12-02 00:03:20 +00:00
}
Logger.Infof("initialized watermark watchdog policy; watermarks: %v; thresholds: %v", p.watermarks, p.thresholds)
return p, nil
2020-12-02 00:03:20 +00:00
}
}
2020-12-02 00:03:20 +00:00
type watermarkPolicy struct {
// watermarks are the percentual amounts of limit.
watermarks []float64
// thresholds are the absolute trigger points of this policy.
thresholds []uint64
limit uint64
}
2020-12-02 00:03:20 +00:00
var _ Policy = (*watermarkPolicy)(nil)
2020-12-02 16:33:00 +00:00
func (w *watermarkPolicy) Evaluate(_ UtilizationType, used uint64) (next uint64, immediate bool) {
Logger.Debugf("watermark policy: evaluating; utilization: %d/%d (used/limit)", used, w.limit)
var i int
for ; i < len(w.thresholds); i++ {
t := w.thresholds[i]
if used < t {
return t, false
2020-12-02 00:03:20 +00:00
}
}
// we reached the maximum threshold, so fire immediately.
return used, true
2020-12-02 00:03:20 +00:00
}