From d340ccd601e22ef3a0f164607cd0426bdd07cb77 Mon Sep 17 00:00:00 2001 From: Emile Vauge Date: Fri, 19 Aug 2016 14:24:09 +0200 Subject: [PATCH] Migrate to JobBackOff --- glide.lock | 22 ++++++++++++-------- glide.yaml | 2 +- integration/utils/try.go | 2 +- provider/consul_catalog.go | 7 +++---- provider/docker.go | 5 ++--- provider/kubernetes.go | 6 ++---- provider/kv.go | 7 +++---- provider/marathon.go | 5 ++--- provider/mesos.go | 5 ++--- utils/retry.go | 41 -------------------------------------- 10 files changed, 30 insertions(+), 72 deletions(-) delete mode 100644 utils/retry.go diff --git a/glide.lock b/glide.lock index 9542d98a7..16fec4b81 100644 --- a/glide.lock +++ b/glide.lock @@ -1,5 +1,5 @@ -hash: 49c7bd0e32b2764248183bda52f168fe22d69e2db5e17c1dbeebbe71be9929b1 -updated: 2016-08-11T14:33:42.826534934+02:00 +hash: 7382685091734eeeef590d8d298600abfaa21c40c8714ef570b8006e4f8cc846 +updated: 2016-08-19T14:15:17.22440385+02:00 imports: - name: github.com/abbot/go-http-auth version: cb4372376e1e00e9f6ab9ec142e029302c9e7140 @@ -25,6 +25,10 @@ imports: version: a819b77bba13f0c0cbe36e437bc2e948411b3996 - name: github.com/containous/staert version: 044bdfee6c8f5e8fb71f70d5ba1cf4cb11a94e97 +- name: github.com/containous/traefik + version: 95e8f0a31e2b5f996e7484c70df1d38fd81b77ce + subpackages: + - utils - name: github.com/coreos/etcd version: 1c9e0a0e33051fed6c05c141e6fcbfe5c7f2a899 subpackages: @@ -36,7 +40,7 @@ imports: subpackages: - spew - name: github.com/docker/distribution - version: 87917f30529e6a7fca8eaff2932424915fb11225 + version: 2b72dd3927b2958160a2336f16145c0c421aa6a4 subpackages: - reference - digest @@ -141,7 +145,7 @@ imports: - lookup - version - name: github.com/docker/libkv - version: aabc039ad04deb721e234f99cd1b4aa28ac71a40 + version: 35d3e2084c650109e7bcc7282655b1bc8ba924ff subpackages: - store - store/boltdb @@ -152,12 +156,14 @@ imports: version: fd1de70867126402be23c306e1ce32828455d85b - name: github.com/elazarl/go-bindata-assetfs version: 57eb5e1fc594ad4b0b1dbea7b286d299e0cb43c2 +- name: github.com/emilevauge/backoff + version: fa0423e7916ea96a4e9789a3710c8e7cb94ecc42 - name: github.com/gambol99/go-marathon version: a558128c87724cd7430060ef5aedf39f83937f55 - name: github.com/go-check/check version: 4f90aeace3a26ad7021961c297b22c42160c7b25 - name: github.com/gogo/protobuf - version: e33835a643a970c11ac74f6333f5f6866387a101 + version: 6abcf94fd4c97dcb423fdafd42fe9f96ca7e421b subpackages: - proto - name: github.com/golang/glog @@ -169,7 +175,7 @@ imports: - name: github.com/gorilla/context version: aed02d124ae4a0e94fea4541c8effd05bf0c8296 - name: github.com/hashicorp/consul - version: 9a353ddd6015378d169f2bee8b3aea44f3d3a03d + version: fce7d75609a04eeb9d4bf41c8dc592aac18fc97d subpackages: - api - name: github.com/hashicorp/go-cleanhttp @@ -220,13 +226,13 @@ imports: - name: github.com/miekg/dns version: 5d001d020961ae1c184f9f8152fdc73810481677 - name: github.com/mitchellh/mapstructure - version: 21a35fb16463dfb7c8eee579c65d995d95e64d1e + version: d2dd0262208475919e1a362f675cfc0e7c10e905 - name: github.com/moul/http2curl version: b1479103caacaa39319f75e7f57fc545287fca0d - name: github.com/ogier/pflag version: 45c278ab3607870051a2ea9040bb85fcb8557481 - name: github.com/opencontainers/runc - version: 1a81e9ab1f138c091fe5c86d0883f87716088527 + version: fb221651e5120cd287a76c7c1b6c877520fbd034 subpackages: - libcontainer/user - name: github.com/parnurzeal/gorequest diff --git a/glide.yaml b/glide.yaml index 62550d75a..d454d5827 100644 --- a/glide.yaml +++ b/glide.yaml @@ -5,7 +5,7 @@ import: subpackages: - fun - package: github.com/Sirupsen/logrus -- package: github.com/cenkalti/backoff +- package: github.com/emilevauge/backoff - package: github.com/codegangsta/negroni - package: github.com/containous/flaeg version: a731c034dda967333efce5f8d276aeff11f8ff87 diff --git a/integration/utils/try.go b/integration/utils/try.go index 595d05fb3..5b1d0b12a 100644 --- a/integration/utils/try.go +++ b/integration/utils/try.go @@ -2,7 +2,7 @@ package utils import ( "errors" - "github.com/cenkalti/backoff" + "github.com/emilevauge/backoff" "net/http" "strconv" "time" diff --git a/provider/consul_catalog.go b/provider/consul_catalog.go index a62edad1b..454ee7f17 100644 --- a/provider/consul_catalog.go +++ b/provider/consul_catalog.go @@ -10,10 +10,9 @@ import ( "github.com/BurntSushi/ty/fun" log "github.com/Sirupsen/logrus" - "github.com/cenkalti/backoff" "github.com/containous/traefik/safe" "github.com/containous/traefik/types" - "github.com/containous/traefik/utils" + "github.com/emilevauge/backoff" "github.com/hashicorp/consul/api" ) @@ -318,10 +317,10 @@ func (provider *ConsulCatalog) Provide(configurationChan chan<- types.ConfigMess notify := func(err error, time time.Duration) { log.Errorf("Consul connection error %+v, retrying in %s", err, time) } - worker := func() error { + operation := func() error { return provider.watch(configurationChan, stop) } - err := utils.RetryNotifyJob(worker, backoff.NewExponentialBackOff(), notify) + err := backoff.RetryNotify(operation, backoff.NewJobBackOff(backoff.NewExponentialBackOff()), notify) if err != nil { log.Errorf("Cannot connect to consul server %+v", err) } diff --git a/provider/docker.go b/provider/docker.go index fbae1c7fa..4e2a696bd 100644 --- a/provider/docker.go +++ b/provider/docker.go @@ -12,16 +12,15 @@ import ( "github.com/BurntSushi/ty/fun" log "github.com/Sirupsen/logrus" - "github.com/cenkalti/backoff" "github.com/containous/traefik/safe" "github.com/containous/traefik/types" - "github.com/containous/traefik/utils" "github.com/containous/traefik/version" "github.com/docker/engine-api/client" dockertypes "github.com/docker/engine-api/types" eventtypes "github.com/docker/engine-api/types/events" "github.com/docker/engine-api/types/filters" "github.com/docker/go-connections/sockets" + "github.com/emilevauge/backoff" "github.com/vdemeester/docker-events" ) @@ -140,7 +139,7 @@ func (provider *Docker) Provide(configurationChan chan<- types.ConfigMessage, po notify := func(err error, time time.Duration) { log.Errorf("Docker connection error %+v, retrying in %s", err, time) } - err := utils.RetryNotifyJob(operation, backoff.NewExponentialBackOff(), notify) + err := backoff.RetryNotify(operation, backoff.NewJobBackOff(backoff.NewExponentialBackOff()), notify) if err != nil { log.Errorf("Cannot connect to docker server %+v", err) } diff --git a/provider/kubernetes.go b/provider/kubernetes.go index b10b5480e..126499334 100644 --- a/provider/kubernetes.go +++ b/provider/kubernetes.go @@ -3,11 +3,10 @@ package provider import ( "fmt" log "github.com/Sirupsen/logrus" - "github.com/cenkalti/backoff" "github.com/containous/traefik/provider/k8s" "github.com/containous/traefik/safe" "github.com/containous/traefik/types" - "github.com/containous/traefik/utils" + "github.com/emilevauge/backoff" "io/ioutil" "os" "reflect" @@ -96,7 +95,6 @@ func (provider *Kubernetes) Provide(configurationChan chan<- types.ConfigMessage if err != nil { return err } - backOff := backoff.NewExponentialBackOff() provider.Constraints = append(provider.Constraints, constraints...) pool.Go(func(stop chan bool) { @@ -147,7 +145,7 @@ func (provider *Kubernetes) Provide(configurationChan chan<- types.ConfigMessage notify := func(err error, time time.Duration) { log.Errorf("Kubernetes connection error %+v, retrying in %s", err, time) } - err := utils.RetryNotifyJob(operation, backOff, notify) + err := backoff.RetryNotify(operation, backoff.NewJobBackOff(backoff.NewExponentialBackOff()), notify) if err != nil { log.Errorf("Cannot connect to Kubernetes server %+v", err) } diff --git a/provider/kv.go b/provider/kv.go index ee874105f..1f70faa57 100644 --- a/provider/kv.go +++ b/provider/kv.go @@ -10,12 +10,11 @@ import ( "errors" "github.com/BurntSushi/ty/fun" log "github.com/Sirupsen/logrus" - "github.com/cenkalti/backoff" "github.com/containous/traefik/safe" "github.com/containous/traefik/types" - "github.com/containous/traefik/utils" "github.com/docker/libkv" "github.com/docker/libkv/store" + "github.com/emilevauge/backoff" ) // Kv holds common configurations of key-value providers. @@ -76,7 +75,7 @@ func (provider *Kv) watchKv(configurationChan chan<- types.ConfigMessage, prefix notify := func(err error, time time.Duration) { log.Errorf("KV connection error: %+v, retrying in %s", err, time) } - err := utils.RetryNotifyJob(operation, backoff.NewExponentialBackOff(), notify) + err := backoff.RetryNotify(operation, backoff.NewJobBackOff(backoff.NewExponentialBackOff()), notify) if err != nil { return fmt.Errorf("Cannot connect to KV server: %v", err) } @@ -106,7 +105,7 @@ func (provider *Kv) provide(configurationChan chan<- types.ConfigMessage, pool * notify := func(err error, time time.Duration) { log.Errorf("KV connection error: %+v, retrying in %s", err, time) } - err := utils.RetryNotifyJob(operation, backoff.NewExponentialBackOff(), notify) + err := backoff.RetryNotify(operation, backoff.NewJobBackOff(backoff.NewExponentialBackOff()), notify) if err != nil { return fmt.Errorf("Cannot connect to KV server: %v", err) } diff --git a/provider/marathon.go b/provider/marathon.go index 606608b1f..0967254f8 100644 --- a/provider/marathon.go +++ b/provider/marathon.go @@ -10,10 +10,9 @@ import ( "github.com/BurntSushi/ty/fun" log "github.com/Sirupsen/logrus" - "github.com/cenkalti/backoff" "github.com/containous/traefik/safe" "github.com/containous/traefik/types" - "github.com/containous/traefik/utils" + "github.com/emilevauge/backoff" "github.com/gambol99/go-marathon" "net/http" "time" @@ -109,7 +108,7 @@ func (provider *Marathon) Provide(configurationChan chan<- types.ConfigMessage, notify := func(err error, time time.Duration) { log.Errorf("Marathon connection error %+v, retrying in %s", err, time) } - err := utils.RetryNotifyJob(operation, backoff.NewExponentialBackOff(), notify) + err := backoff.RetryNotify(operation, backoff.NewJobBackOff(backoff.NewExponentialBackOff()), notify) if err != nil { log.Errorf("Cannot connect to Marathon server %+v", err) } diff --git a/provider/mesos.go b/provider/mesos.go index a9a442096..83b8e3757 100644 --- a/provider/mesos.go +++ b/provider/mesos.go @@ -9,10 +9,9 @@ import ( "fmt" "github.com/BurntSushi/ty/fun" log "github.com/Sirupsen/logrus" - "github.com/cenkalti/backoff" "github.com/containous/traefik/safe" "github.com/containous/traefik/types" - "github.com/containous/traefik/utils" + "github.com/emilevauge/backoff" "github.com/mesos/mesos-go/detector" _ "github.com/mesos/mesos-go/detector/zoo" // Registers the ZK detector "github.com/mesosphere/mesos-dns/detect" @@ -111,7 +110,7 @@ func (provider *Mesos) Provide(configurationChan chan<- types.ConfigMessage, poo notify := func(err error, time time.Duration) { log.Errorf("mesos connection error %+v, retrying in %s", err, time) } - err := utils.RetryNotifyJob(operation, backoff.NewExponentialBackOff(), notify) + err := backoff.RetryNotify(operation, backoff.NewJobBackOff(backoff.NewExponentialBackOff()), notify) if err != nil { log.Errorf("Cannot connect to mesos server %+v", err) } diff --git a/utils/retry.go b/utils/retry.go deleted file mode 100644 index 7ec100ee9..000000000 --- a/utils/retry.go +++ /dev/null @@ -1,41 +0,0 @@ -package utils - -import ( - "github.com/cenkalti/backoff" - "time" -) - -const ( - minLongJobInterval = 30 * time.Second -) - -// RetryNotifyJob calls notify function with the error and wait duration -// for each failed attempt before sleep. -func RetryNotifyJob(operation backoff.Operation, b backoff.BackOff, notify backoff.Notify) error { - var err error - var next time.Duration - - b.Reset() - for { - before := time.Now() - if err = operation(); err == nil { - return nil - } - elapsed := time.Since(before) - - // If long job, we reset the backoff - if elapsed >= minLongJobInterval { - b.Reset() - } - - if next = b.NextBackOff(); next == backoff.Stop { - return err - } - - if notify != nil { - notify(err, next) - } - - time.Sleep(next) - } -}