seaweedfs/weed/util/retry.go

102 lines
1.9 KiB
Go
Raw Permalink Normal View History

package util
import (
2020-11-01 08:21:44 +00:00
"strings"
"time"
"github.com/seaweedfs/seaweedfs/weed/glog"
)
2020-11-01 10:36:43 +00:00
var RetryWaitTime = 6 * time.Second
func Retry(name string, job func() error) (err error) {
waitTime := time.Second
2020-11-01 08:40:16 +00:00
hasErr := false
2020-11-01 10:36:43 +00:00
for waitTime < RetryWaitTime {
err = job()
if err == nil {
2020-11-01 08:40:16 +00:00
if hasErr {
glog.V(0).Infof("retry %s successfully", name)
}
2023-05-08 06:39:33 +00:00
waitTime = time.Second
break
}
2020-11-01 08:40:16 +00:00
if strings.Contains(err.Error(), "transport") {
hasErr = true
glog.V(0).Infof("retry %s: err: %v", name, err)
} else {
break
2020-11-01 08:21:44 +00:00
}
2022-08-21 06:34:45 +00:00
time.Sleep(waitTime)
waitTime += waitTime / 2
}
return err
2020-11-01 10:36:43 +00:00
}
2020-11-16 00:58:48 +00:00
func MultiRetry(name string, errList []string, job func() error) (err error) {
waitTime := time.Second
hasErr := false
for waitTime < RetryWaitTime {
err = job()
if err == nil {
if hasErr {
glog.V(0).Infof("retry %s successfully", name)
}
2023-05-08 06:39:33 +00:00
waitTime = time.Second
break
}
if containErr(err.Error(), errList) {
hasErr = true
glog.V(0).Infof("retry %s: err: %v", name, err)
} else {
break
}
time.Sleep(waitTime)
waitTime += waitTime / 2
}
return err
}
2023-10-01 18:33:56 +00:00
// RetryUntil retries until the job returns no error or onErrFn returns false
func RetryUntil(name string, job func() error, onErrFn func(err error) (shouldContinue bool)) {
2021-08-15 19:37:35 +00:00
waitTime := time.Second
for {
2021-08-15 19:40:22 +00:00
err := job()
2021-08-15 19:37:35 +00:00
if err == nil {
2021-09-03 02:55:01 +00:00
waitTime = time.Second
2021-08-15 19:37:35 +00:00
break
}
if onErrFn(err) {
if strings.Contains(err.Error(), "transport") {
glog.V(0).Infof("retry %s: err: %v", name, err)
2021-08-16 03:06:47 +00:00
}
time.Sleep(waitTime)
if waitTime < RetryWaitTime {
waitTime += waitTime / 2
2021-08-15 19:37:35 +00:00
}
continue
2023-10-01 18:33:56 +00:00
} else {
break
2021-08-15 19:37:35 +00:00
}
}
}
2023-10-01 18:36:27 +00:00
// Nvl return the first non-empty string
2020-11-16 00:58:48 +00:00
func Nvl(values ...string) string {
for _, s := range values {
if s != "" {
return s
}
}
return ""
}
func containErr(err string, errList []string) bool {
for _, e := range errList {
if strings.Contains(err, e) {
return true
}
}
return false
}