Skip to content

Commit

Permalink
add exponential backoff for docker api calls
Browse files Browse the repository at this point in the history
  • Loading branch information
Mahmood Ali committed Sep 18, 2019
1 parent d505168 commit b5b445c
Showing 1 changed file with 10 additions and 3 deletions.
13 changes: 10 additions & 3 deletions drivers/docker/driver.go
Original file line number Diff line number Diff line change
Expand Up @@ -455,7 +455,7 @@ CREATE:

if attempted < 5 {
attempted++
time.Sleep(1 * time.Second)
time.Sleep(nextBackoff(attempted))
goto CREATE
}
} else if strings.Contains(strings.ToLower(createErr.Error()), "no such image") {
Expand All @@ -464,7 +464,7 @@ CREATE:
return nil, nstructs.NewRecoverableError(createErr, true)
} else if isDockerTransientError(createErr) && attempted < 5 {
attempted++
time.Sleep(1 * time.Second)
time.Sleep(nextBackoff(attempted))
goto CREATE
}

Expand All @@ -487,7 +487,7 @@ START:
if isDockerTransientError(startErr) {
if attempted < 5 {
attempted++
time.Sleep(1 * time.Second)
time.Sleep(nextBackoff(attempted))
goto START
}
return nstructs.NewRecoverableError(startErr, true)
Expand All @@ -496,6 +496,13 @@ START:
return recoverableErrTimeouts(startErr)
}

// nextBackoff returns appropriate docker backoff durations after attempted attempts.
func nextBackoff(attempted int) time.Duration {
// attempts in 200ms, 800ms, 3.2s, 12.8s, 51.2s
// TODO: add randomization factor and extract to a helper
return 1 << (2 * uint64(attempted)) * 50 * time.Millisecond
}

// createImage creates a docker image either by pulling it from a registry or by
// loading it from the file system
func (d *Driver) createImage(task *drivers.TaskConfig, driverConfig *TaskConfig, client *docker.Client) (string, error) {
Expand Down

0 comments on commit b5b445c

Please sign in to comment.