mirror of
https://github.com/caddyserver/caddy.git
synced 2025-03-09 15:39:02 -04:00
admin, reverseproxy: Stop timers if canceled to avoid goroutine leak (#4482)
This commit is contained in:
parent
249adc1c87
commit
2e46c2ac1d
7
caddy.go
7
caddy.go
@ -494,9 +494,10 @@ func finishSettingUp(ctx Context, cfg *Config) error {
|
||||
if cfg.Admin.Config.LoadInterval > 0 {
|
||||
go func() {
|
||||
for {
|
||||
timer := time.NewTimer(time.Duration(cfg.Admin.Config.LoadInterval))
|
||||
select {
|
||||
// if LoadInterval is positive, will wait for the interval and then run with new config
|
||||
case <-time.After(time.Duration(cfg.Admin.Config.LoadInterval)):
|
||||
case <-timer.C:
|
||||
loadedConfig, err := val.(ConfigLoader).LoadConfig(ctx)
|
||||
if err != nil {
|
||||
Log().Error("loading dynamic config failed", zap.Error(err))
|
||||
@ -504,6 +505,10 @@ func finishSettingUp(ctx Context, cfg *Config) error {
|
||||
}
|
||||
runLoadedConfig(loadedConfig)
|
||||
case <-ctx.Done():
|
||||
if !timer.Stop() {
|
||||
// if the timer has been stopped then read from the channel
|
||||
<-timer.C
|
||||
}
|
||||
Log().Info("stopping config load interval")
|
||||
return
|
||||
}
|
||||
|
@ -792,10 +792,15 @@ func (lb LoadBalancing) tryAgain(ctx caddy.Context, start time.Time, proxyErr er
|
||||
}
|
||||
|
||||
// otherwise, wait and try the next available host
|
||||
timer := time.NewTimer(time.Duration(lb.TryInterval))
|
||||
select {
|
||||
case <-time.After(time.Duration(lb.TryInterval)):
|
||||
case <-timer.C:
|
||||
return true
|
||||
case <-ctx.Done():
|
||||
if !timer.Stop() {
|
||||
// if the timer has been stopped then read from the channel
|
||||
<-timer.C
|
||||
}
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user