123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- package util
- import (
- "strings"
- "time"
- "github.com/seaweedfs/seaweedfs/weed/glog"
- )
- var RetryWaitTime = 6 * time.Second
- func Retry(name 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)
- }
- waitTime = time.Second
- break
- }
- if strings.Contains(err.Error(), "transport") {
- hasErr = true
- glog.V(0).Infof("retry %s: err: %v", name, err)
- } else {
- break
- }
- time.Sleep(waitTime)
- waitTime += waitTime / 2
- }
- return err
- }
- 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)
- }
- 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
- }
- // 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)) {
- waitTime := time.Second
- for {
- err := job()
- if err == nil {
- waitTime = time.Second
- break
- }
- if onErrFn(err) {
- if strings.Contains(err.Error(), "transport") {
- glog.V(0).Infof("retry %s: err: %v", name, err)
- }
- time.Sleep(waitTime)
- if waitTime < RetryWaitTime {
- waitTime += waitTime / 2
- }
- continue
- } else {
- break
- }
- }
- }
- // Nvl return the first non-empty string
- 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
- }
|