MCPcopy
hub / github.com/uber-go/automaxprocs

github.com/uber-go/automaxprocs @v1.6.0 sqlite

repository ↗ · DeepWiki ↗ · release v1.6.0 ↗
78 symbols 229 edges 24 files 29 documented · 37%
README

automaxprocs GoDoc Build Status Coverage Status

Automatically set GOMAXPROCS to match Linux container CPU quota.

Installation

go get -u go.uber.org/automaxprocs

Quick Start

import _ "go.uber.org/automaxprocs"

func main() {
  // Your application logic here.
}

Performance

Data measured from Uber's internal load balancer. We ran the load balancer with 200% CPU quota (i.e., 2 cores):

GOMAXPROCS RPS P50 (ms) P99.9 (ms)
1 28,893.18 1.46 19.70
2 (equal to quota) 44,715.07 0.84 26.38
3 44,212.93 0.66 30.07
4 41,071.15 0.57 42.94
8 33,111.69 0.43 64.32
Default (24) 22,191.40 0.45 76.19

When GOMAXPROCS is increased above the CPU quota, we see P50 decrease slightly, but see significant increases to P99. We also see that the total RPS handled also decreases.

When GOMAXPROCS is higher than the CPU quota allocated, we also saw significant throttling:

$ cat /sys/fs/cgroup/cpu,cpuacct/system.slice/[...]/cpu.stat
nr_periods 42227334
nr_throttled 131923
throttled_time 88613212216618

Once GOMAXPROCS was reduced to match the CPU quota, we saw no CPU throttling.

Development Status: Stable

All APIs are finalized, and no breaking changes will be made in the 1.x series of releases. Users of semver-aware dependency management systems should pin automaxprocs to ^1.

Contributing

We encourage and support an active, healthy community of contributors — including you! Details are in the contribution guide and the code of conduct. The automaxprocs maintainers keep an eye on issues and pull requests, but you can also report any negative conduct to oss-conduct@uber.com. That email list is a private, safe space; even the automaxprocs maintainers don't have access, so don't hesitate to hold us to a high standard.


Released under the MIT License.

Extension points exported contracts — how you extend this code

Option (Interface)
An Option alters the behavior of Set.
maxprocs/maxprocs.go

Core symbols most depended-on inside this repo

currentMaxProcs
called by 17
maxprocs/maxprocs.go
Error
called by 14
internal/cgroups/errors.go
Set
called by 14
maxprocs/maxprocs.go
NewMountPointFromLine
called by 6
internal/cgroups/mountpoint.go
log
called by 6
maxprocs/maxprocs.go
newCGroups2From
called by 5
internal/cgroups/cgroups2.go
NewCGroup
called by 5
internal/cgroups/cgroup.go
CPUQuota
called by 5
internal/runtime/cpu_quota_linux.go

Shape

Function 49
Method 15
Struct 9
Interface 2
TypeAlias 2
FuncType 1

Languages

Go100%

Modules by API surface

maxprocs/maxprocs.go11 symbols
maxprocs/maxprocs_test.go6 symbols
internal/cgroups/errors.go6 symbols
internal/cgroups/cgroup.go6 symbols
internal/cgroups/cgroups2_test.go5 symbols
internal/cgroups/cgroups2.go5 symbols
internal/runtime/cpu_quota_linux_test.go4 symbols
internal/runtime/cpu_quota_linux.go4 symbols
internal/cgroups/mountpoint_test.go4 symbols
internal/cgroups/mountpoint.go4 symbols
internal/cgroups/cgroups.go4 symbols
internal/cgroups/subsys.go3 symbols

Dependencies from manifests, versioned

github.com/kr/prettyv0.1.0 · 1×
github.com/pmezard/go-difflibv1.0.0 · 1×
github.com/prashantv/gostubv1.1.0 · 1×
golang.org/x/exp/typeparamsv0.0.0-2022032817524 · 1×
golang.org/x/lintv0.0.0-2021050822211 · 1×
golang.org/x/modv0.6.0-dev.0.2022010 · 1×
golang.org/x/sysv0.1.0 · 1×
golang.org/x/toolsv0.1.10 · 1×
golang.org/x/xerrorsv0.0.0-2020080418410 · 1×

For agents

$ claude mcp add automaxprocs \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact