go: net/http: permanently broken connection with error "read: connection reset by peer" when response body is not closed
What version of Go are you using (go version
)?
Go 1.14 beta 1
Does this issue reproduce with the latest release?
Not sure; I can’t compile my program with 1.13.
What operating system and processor architecture are you using (go env
)?
go env
Output
$ go env GO111MODULE="" GOARCH="amd64" GOBIN="" GOCACHE="/Users/josh/Library/Caches/go-build" GOENV="/Users/josh/Library/Application Support/go/env" GOEXE="" GOFLAGS="" GOHOSTARCH="amd64" GOHOSTOS="darwin" GOINSECURE="" GONOPROXY="" GONOSUMDB="" GOOS="darwin" GOPATH="/Users/josh" GOPRIVATE="" GOPROXY="https://proxy.golang.org,direct" GOROOT="/Users/josh/go/1.14" GOSUMDB="sum.golang.org" GOTMPDIR="" GOTOOLDIR="/Users/josh/go/1.14/pkg/tool/darwin_amd64" GCCGO="gccgo" AR="ar" CC="clang" CXX="clang++" CGO_ENABLED="1" GOMOD="/Users/josh/x/skiff/go.mod" CGO_CFLAGS="-g -O2" CGO_CPPFLAGS="" CGO_CXXFLAGS="-g -O2" CGO_FFLAGS="-g -O2" CGO_LDFLAGS="-g -O2" PKG_CONFIG="pkg-config" GOGCCFLAGS="-fPIC -m64 -pthread -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -fdebug-prefix-map=/var/folders/1t/n61cbvls5bl293bbb0zyypqw0000gn/T/go-build473522411=/tmp/go-build -gno-record-gcc-switches -fno-common"
What did you do?
Made a series of http requests from a Go client to a Go server. The requests were vanilla HTTP requests, using http.Get
.
I lost connectivity at some point. When I regained connectivity, all subsequent http requests failed with error read: connection reset by peer
. I waited quite a long time, and it never recovered.
It has happened a couple of times, but doesn’t reproduce reliably (which is unsurprising, since me closing my laptop lid is not exactly a precision affair).
This looks very similar to #34978, although I don’t know when exactly the connectivity failed.
Tentatively marking as Go 1.14.
About this issue
- Original URL
- State: open
- Created 4 years ago
- Comments: 19 (16 by maintainers)
Possibly related: I just saw this error message in our CI system. I couldn’t reproduce it, but I can’t see why closing idle connections should cause this kind of error: