seaweedfs/weed/util/retry.go

44 lines
733 B
Go
Raw Normal View History

package util
import (
2020-11-01 16:21:44 +08:00
"strings"
"time"
"github.com/chrislusf/seaweedfs/weed/glog"
)
2020-11-01 18:36:43 +08:00
var RetryWaitTime = 6 * time.Second
func Retry(name string, job func() error) (err error) {
waitTime := time.Second
2020-11-01 16:40:16 +08:00
hasErr := false
2020-11-01 18:36:43 +08:00
for waitTime < RetryWaitTime {
err = job()
if err == nil {
2020-11-01 16:40:16 +08:00
if hasErr {
glog.V(0).Infof("retry %s successfully", name)
}
break
}
2020-11-01 16:40:16 +08:00
if strings.Contains(err.Error(), "transport") {
hasErr = true
glog.V(0).Infof("retry %s: err: %v", name, err)
2020-11-01 16:21:44 +08:00
time.Sleep(waitTime)
waitTime += waitTime / 2
} else {
break
2020-11-01 16:21:44 +08:00
}
}
return err
2020-11-01 18:36:43 +08:00
}
2020-11-16 08:58:48 +08:00
// return the first non empty string
func Nvl(values ...string) string {
for _, s := range values {
if s != "" {
return s
}
}
return ""
}