You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Common Readers (such as io.Pipe) return an error when someone tries to read from it after it has been closed. This happens here when Goroutine (2) closes the Reader and Goroutine (1) is still trying to copy data from it.
When the Go scheduler now decides to switch Goroutines between these two lines
Recently, Nomad switched from go-dockerclient to the native SDK. I would say that the bug is still valid and relevant, but not in the context of Nomad.
Expected Behavior
We consistently receive no error for an exec in a container (thread-safe).
Current Behavior
Sometimes the
StartExec
function is returning the errorio: read/write on closed pipe
.This happens once with around:
go run -race main
)Steps to Reproduce
docker pull ubuntu
go mod init main
go get github.com/fsouza/go-dockerclient
go run -race main.go
.Possible Solution
The error originates in the forwarding of the StdIn stream, here.
One Goroutine (1) is started to copy the StdIn to the Docker Deamon.
go-dockerclient/client.go
Lines 826 to 835 in 87c2a33
Another Goroutine (2) copies the StdOut from the Daemon. However, when the copy of the StdOut stream finishes, the Input Reader is closed.
go-dockerclient/client.go
Lines 806 to 823 in 87c2a33
Common Readers (such as
io.Pipe
) return an error when someone tries to read from it after it has been closed. This happens here when Goroutine (2) closes the Reader and Goroutine (1) is still trying to copy data from it.When the Go scheduler now decides to switch Goroutines between these two lines
go-dockerclient/client.go
Lines 810 to 812 in 87c2a33
to these two lines
go-dockerclient/client.go
Lines 829 to 831 in 87c2a33
an unexpected error is being returned.
Context (Environment)
This scenario is relevant as the Nomad orchestrator triggers it regularly.
The text was updated successfully, but these errors were encountered: