1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- 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
- }
- func RetryForever(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
- }
- }
- }
- // 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
- }
|