bdc5533f39
With the Garbage collector (GC), we observed a false-sharing between work.full and work.empty. (referenced most from runtime.gcDrain and runtime.getempty) This false-sharing becomes worse and impact performance on multi core system. On Intel Xeon 8480+ and default GC setting(GC=100), we can observed top HITM>4% (by perf c2c)caused by it. After resolveed this false-sharing issue, we can get performance 8%~9.7% improved. Verify workloads: DeathStarBench/hotelReservation: 9.7% of RPS improved https://github.com/delimitrou/DeathStarBench/tree/master/hotelReservation gRPC-go/benchmark: 8% of RPS improved https://github.com/grpc/grpc-go/tree/master/benchmark gRPC-go/benchmark 9 iterations' data with master branch: master w/ fs opt. 208862.4 246390.9 221680.0 266019.3 223886.9 248789.7 212169.3 257837.8 219922.4 234331.8 197401.7 261627.7 214562.4 255429.7 214328.5 237087.8 229443.2 230591.3 max 229443.2 266019.3 116% med 214562.4 248789.7 116% avg 215806.3 248678.5 115% Change-Id: Ib386de021cd2dbb802a107f487556d848ba9212d Reviewed-on: https://go-review.googlesource.com/c/go/+/496915 Reviewed-by: Keith Randall <khr@golang.org> Reviewed-by: Michael Knyszek <mknyszek@google.com> TryBot-Result: Gopher Robot <gobot@golang.org> Auto-Submit: Keith Randall <khr@golang.org> Reviewed-by: Keith Randall <khr@google.com> Run-TryBot: Keith Randall <khr@golang.org> |
||
---|---|---|
.github | ||
api | ||
doc | ||
lib/time | ||
misc | ||
src | ||
test | ||
.gitattributes | ||
.gitignore | ||
codereview.cfg | ||
CONTRIBUTING.md | ||
go.env | ||
LICENSE | ||
PATENTS | ||
README.md | ||
SECURITY.md |
The Go Programming Language
Go is an open source programming language that makes it easy to build simple, reliable, and efficient software.
Gopher image by Renee French, licensed under Creative Commons 4.0 Attributions license.
Our canonical Git repository is located at https://go.googlesource.com/go. There is a mirror of the repository at https://github.com/golang/go.
Unless otherwise noted, the Go source files are distributed under the BSD-style license found in the LICENSE file.
Download and Install
Binary Distributions
Official binary distributions are available at https://go.dev/dl/.
After downloading a binary release, visit https://go.dev/doc/install for installation instructions.
Install From Source
If a binary distribution is not available for your combination of operating system and architecture, visit https://go.dev/doc/install/source for source installation instructions.
Contributing
Go is the work of thousands of contributors. We appreciate your help!
To contribute, please read the contribution guidelines at https://go.dev/doc/contribute.
Note that the Go project uses the issue tracker for bug reports and proposals only. See https://go.dev/wiki/Questions for a list of places to ask questions about the Go language.