seaweedfs/weed/util/retry.go

24 lines
438 B
Go
Raw Normal View History

package util
import (
2020-11-01 08:21:44 +00:00
"strings"
"time"
"github.com/chrislusf/seaweedfs/weed/glog"
)
func Retry(name string, waitTimeLimit time.Duration, job func() error) (err error) {
waitTime := time.Second
for waitTime < waitTimeLimit {
err = job()
if err == nil {
break
}
2020-11-01 08:21:44 +00:00
if strings.Contains(err.Error(), "transport: ") {
glog.V(1).Infof("retry %s", name)
time.Sleep(waitTime)
waitTime += waitTime / 2
}
}
return err
}