fix: avoid race condition by not running exec/start twice (#702)
ContainerExecAttach implicitly runs ContainerExecStart while attaching
to stdout/stderr.
Ref: e02bc91dcb/client/container_exec.go (L40)
Calling both can lead to a race condition as observed in #627
Fixes: #627
Co-authored-by: Markus Wolf <markus.wolf@new-work.se>
Co-authored-by: Markus Wolf <markus.wolf@new-work.se>
This commit is contained in:
parent
d794e2fe4c
commit
8a9167da82
1 changed files with 0 additions and 7 deletions
|
@ -456,13 +456,6 @@ func (cr *containerReference) exec(cmd []string, env map[string]string, user str
|
||||||
errWriter = os.Stderr
|
errWriter = os.Stderr
|
||||||
}
|
}
|
||||||
|
|
||||||
err = cr.cli.ContainerExecStart(ctx, idResp.ID, types.ExecStartCheck{
|
|
||||||
Tty: isTerminal,
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return errors.WithStack(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !isTerminal || os.Getenv("NORAW") != "" {
|
if !isTerminal || os.Getenv("NORAW") != "" {
|
||||||
_, err = stdcopy.StdCopy(outWriter, errWriter, resp.Reader)
|
_, err = stdcopy.StdCopy(outWriter, errWriter, resp.Reader)
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue