mount: add retry for all operations with filer

fix https://github.com/chrislusf/seaweedfs/issues/1589
This commit is contained in:
Chris Lu
2020-11-01 01:11:08 -07:00
parent de86945aeb
commit f7b21973ac
2 changed files with 29 additions and 4 deletions

21
weed/util/retry.go Normal file
View File

@@ -0,0 +1,21 @@
package util
import (
"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
}
glog.V(1).Infof("retry %s", name)
time.Sleep(waitTime)
waitTime += waitTime / 2
}
return err
}