go x/net/http2: TCP段利用率低

fzwojiic  于 6个月前  发布在  Go
关注(0)|答案(1)|浏览(43)

你正在使用的Go版本是什么( go version )?

$ go version
go version go1.14.2 darwin/amd64

这个问题在最新版本的发布中是否会重现?

是的

你正在使用什么操作系统和处理器架构( go env )?

go env 输出

$ go env
GO111MODULE="on"
GOARCH="amd64"
GOBIN=""
GOCACHE="/Users/detailyang/Library/Caches/go-build"
GOENV="/Users/detailyang/Library/Application Support/go/env"
GOEXE=""
GOFLAGS=""
GOHOSTARCH="amd64"
GOHOSTOS="darwin"
GOINSECURE=""
GONOPROXY="**.baidu.com**"
GONOSUMDB="*"
GOOS="darwin"
GOPATH="/Users/detailyang/go"
GOPRIVATE=""
GOPROXY="https://goproxy.baidu.com,https://goproxy.cn,direct"
GOROOT="/usr/local/go"
GOSUMDB="off"
GOTMPDIR=""
GOTOOLDIR="/usr/local/go/pkg/tool/darwin_amd64"
GCCGO="gccgo"
AR="ar"
CC="clang"
CXX="clang++"
CGO_ENABLED="1"
GOMOD="/dev/null"
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/n3/g3fv953s435gqv0x7557ftyc0000gp/T/go-build515636404=/tmp/go-build -gno-record-gcc-switches -fno-common"

你做了什么?

启动一个http2回显服务器,然后写入响应

你期望看到什么?

我期望看到响应 Header FrameDataFrameHeader Frame with EndStream 可以编码到一个TCP段中,但实际上并不是这样:(

你看到了什么?

一个http2响应被分成了3个TCP段,这意味着性能较差。相关的代码库如下:https://github.com/golang/net/blob/master/http2/server.go#L2393-L2499
底层的serveConn.wantWriteFrameCh应该考虑如何批量获取数据

相关问题