Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Investigate autosetting GOMAXPROCS and GOMEMLIMIT env vars #27

Open
jtackaberry opened this issue Jun 13, 2024 · 3 comments
Open

Investigate autosetting GOMAXPROCS and GOMEMLIMIT env vars #27

jtackaberry opened this issue Jun 13, 2024 · 3 comments
Assignees

Comments

@jtackaberry
Copy link
Collaborator

See rqlite/rqlite#1804

@jtackaberry jtackaberry self-assigned this Jun 13, 2024
@otoolep
Copy link
Member

otoolep commented Jun 13, 2024

I haven't read the blog post, but I am not sure I would touch GOMAXPROCS. AFAIK it just does the right thing if not explicitly set:

https://pkg.go.dev/runtime#GOMAXPROCS

As for GOMEMLIMTI, well, tweaking the GC can be subtle.

rqlite can definitely OOM if one sends many large requests to it. I got some reports of OOMs recently. But the best way to deal with that is to lower GOGC and see if that helps (it did in the recent cases). See Go's GC guide for more details. I also added a note about all this recently to the rqlite docs

So not saying there isn't a case for doing some stuff automatically but, just like the JVM, tuning GC always looks simple to start, but can have unintended consequences.

@jtackaberry
Copy link
Collaborator Author

jtackaberry commented Jun 13, 2024

I haven't read the blog post, but I am not sure I would touch GOMAXPROCS. AFAIK it just does the right thing if not explicitly set:

Not in the context of cgroups limits. The blog is worth reading, but it also links out to golang/go#33803. It looks like cgroups-aware behavior may land at some point in the future, and while it's not in place now, the theory involved looks sound.

As for GOMEMLIMTI, well, tweaking the GC can be subtle.

Consider a Go process running on a host with 64GB of RAM, 60GB of which is free, but a pod memory limit of 2GB. Go is going to act as though it's running on a system with 60G free, and it will not GC as aggressively as it would if it only had 2GB free, so it will keep humming along accumulating garbage until it's too late and the cgroups limit kicks in and the kernel OOM-kills it. Setting GOMEMLIMIT to the cgroups-imposed limit will induce GC earlier, which seems more desirable than summary execution.

rqlite can definitely OOM if one sends many large requests to it. I got some reports of OOMs recently. But the best way to deal with that is to lower GOGC and see if that helps (it did in the recent cases). See Go's GC guide for more details. I also added a note about all this recently to the rqlite docs

Dialing back GOGC isn't going to help when the runtime thinks it has 60GB of free memory. (Well, not unless you set it to like 2 :))

GOMEMLIMIT is reasonable. For the day job, we do set it in some cases for Go workloads in Kubernetes for this very reason. I've just never done it for GOMAXPROCS, but I'm not seeing any fault in the theory.

So not saying there isn't a case for doing some stuff automatically but, just like the JVM, tuning GC always looks simple to start, but can have unintended consequences.

Which is actually why I'm more inclined to change GOMEMLIMIT than GOGC. GOGC, it seems to me, can have more subtle and complex nuances than GOMEMLIMIT.

@otoolep
Copy link
Member

otoolep commented Jun 13, 2024

That is interesting -- good to read, thanks. I'll keep an eye on this issue, see what you decide to do (if anything).

@otoolep otoolep changed the title Ingestigate autosetting GOMAXPROCS and GOMEMLIMIT env vars Investigate autosetting GOMAXPROCS and GOMEMLIMIT env vars Jun 13, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants