From 49ee34c1e321c15ae33403aa8138407ff5b03f10 Mon Sep 17 00:00:00 2001 From: Alex Dadgar Date: Fri, 25 Nov 2016 19:22:58 -0800 Subject: [PATCH] Make container exist errors non-retriable This change makes it so that the task runner does not retry container exists errors and also a sleep is added on the local retry. --- client/driver/docker.go | 4 ++-- demo/vagrant/client1.hcl | 6 ++++++ demo/vagrant/client2.hcl | 6 ++++++ demo/vagrant/server.hcl | 6 ++++++ 4 files changed, 20 insertions(+), 2 deletions(-) diff --git a/client/driver/docker.go b/client/driver/docker.go index c3a0268d3c7..7d1c57fed8a 100644 --- a/client/driver/docker.go +++ b/client/driver/docker.go @@ -949,8 +949,7 @@ func (d *DockerDriver) createContainer(config docker.CreateContainerOptions) (*d recoverable := func(err error) *structs.RecoverableError { r := false if strings.Contains(err.Error(), "Client.Timeout exceeded while awaiting headers") || - strings.Contains(err.Error(), "EOF") || - strings.Contains(err.Error(), "container already exists") { + strings.Contains(err.Error(), "EOF") { r = true } return structs.NewRecoverableError(err, r) @@ -997,6 +996,7 @@ CREATE: if attempted < 5 { attempted++ + time.Sleep(1 * time.Second) goto CREATE } } diff --git a/demo/vagrant/client1.hcl b/demo/vagrant/client1.hcl index ace6412b793..24083ee3f46 100644 --- a/demo/vagrant/client1.hcl +++ b/demo/vagrant/client1.hcl @@ -29,3 +29,9 @@ client { ports { http = 5656 } + +advertise { + http = "localhost" + rpc = "localhost" + serf = "localhost" +} diff --git a/demo/vagrant/client2.hcl b/demo/vagrant/client2.hcl index 1b1372ae2a8..31b74ad1df2 100644 --- a/demo/vagrant/client2.hcl +++ b/demo/vagrant/client2.hcl @@ -23,3 +23,9 @@ client { ports { http = 5657 } + +advertise { + http = "localhost" + rpc = "localhost" + serf = "localhost" +} diff --git a/demo/vagrant/server.hcl b/demo/vagrant/server.hcl index 653b2c0379e..5361af54f75 100644 --- a/demo/vagrant/server.hcl +++ b/demo/vagrant/server.hcl @@ -11,3 +11,9 @@ server { # Self-elect, should be 3 or 5 for production bootstrap_expect = 1 } + +advertise { + http = "localhost" + rpc = "localhost" + serf = "localhost" +}