Skip to content

Commit

Permalink
Merge pull request #4599 from hashicorp/f-docker-kill-timeout
Browse files Browse the repository at this point in the history
Fix kill timeout exceeding 5m on Docker driver
  • Loading branch information
dadgar authored Aug 20, 2018
2 parents 92d9168 + 383251f commit afaec81
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 1 deletion.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ IMPROVEMENTS:

BUG FIXES:
* core: Reset queued allocation summary to zero when job stopped [[GH-4414](https://github.com/hashicorp/nomad/issues/4414)]
* driver/docker: Fix kill timeout not being respected when timeout is over five
minutes [[GH-4599](https://github.com/hashicorp/nomad/issues/4599)]

## 0.8.4 (June 11, 2018)

Expand Down
2 changes: 1 addition & 1 deletion client/driver/docker.go
Original file line number Diff line number Diff line change
Expand Up @@ -1913,7 +1913,7 @@ func (h *DockerHandle) Signal(s os.Signal) error {
// Kill is used to terminate the task. This uses `docker stop -t killTimeout`
func (h *DockerHandle) Kill() error {
// Stop the container
err := h.client.StopContainer(h.containerID, uint(h.killTimeout.Seconds()))
err := h.waitClient.StopContainer(h.containerID, uint(h.killTimeout.Seconds()))
if err != nil {
h.executor.Exit()
h.pluginClient.Kill()
Expand Down
53 changes: 53 additions & 0 deletions client/driver/docker_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -695,6 +695,59 @@ func TestDockerDriver_Start_Kill_Wait(t *testing.T) {
}
}

func TestDockerDriver_Start_KillTimeout(t *testing.T) {
if !tu.IsTravis() {
t.Parallel()
}
if !testutil.DockerIsConnected(t) {
t.Skip("Docker not connected")
}
timeout := 2 * time.Second
task := &structs.Task{
Name: "nc-demo",
Driver: "docker",
Config: map[string]interface{}{
"image": "busybox",
"load": "busybox.tar",
"command": "/bin/sleep",
"args": []string{"10"},
},
LogConfig: &structs.LogConfig{
MaxFiles: 10,
MaxFileSizeMB: 10,
},
Resources: basicResources,
KillTimeout: timeout,
KillSignal: "SIGUSR1", // Pick something that doesn't actually kill it
}

_, handle, cleanup := dockerSetup(t, task)
defer cleanup()

// Reduce the timeout for the docker client.
handle.client.SetTimeout(1 * time.Second)

// Kill the task
var killSent, killed time.Time
go func() {
killSent = time.Now()
if err := handle.Kill(); err != nil {
t.Fatalf("err: %v", err)
}
}()

select {
case <-handle.WaitCh():
killed = time.Now()
case <-time.After(10 * time.Second):
t.Fatalf("timeout")
}

if killed.Sub(killSent) < timeout {
t.Fatalf("kill timeout not respected")
}
}

func TestDockerDriver_StartN(t *testing.T) {
if !tu.IsTravis() {
t.Parallel()
Expand Down

0 comments on commit afaec81

Please sign in to comment.