-
Notifications
You must be signed in to change notification settings - Fork 17.9k
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
proposal: runtime: add a default, non-destructive signal handler that creates a stack dump #64687
Comments
In theory you could build this as a library using |
I also think this is fairly simple to implement in a separate package, and one might depend on different conditions for it to trigger. Here we are discussing signal handlers, but maybe someone else wants to create a dump when memory reaches a certain threshold, or some other condition is reached. I like the idea of a general api involving |
I agree that this seems easily implementable outside of the standard library. It also doesn't seem like a common requirement. Is there a good reason to put this in the standard library? See https://go.dev/doc/faq#x_in_std. |
In my experience, enterprise software is exponentially more difficult to support and maintain if simple diagnostics need to be bolted on rather than provided "in the box" (I'm not a Go expert, but I presume "in the box" is equivalent to "inside the standard library"). This feature request was driven by a production incident where we could not get the simple diagnostic of a thread dump that shows what all threads are doing (the program was in a container, so we couldn't easily try |
Proposal Details
By default, Go produces a stack dump and exits on various signals:
It is commonly desired to create such a stack dump using a mechanism such as a signal but without exiting. Such thread dumps may be used to investigate hangs or as a rudimentary sampling profiler. Such built-in handlers are common in other languages such as Java (e.g. using
SIGQUIT
).One way for a program to handle this requirement is to handle a signal such as
SIGUSR1
, generate a stack dump by callingpprof.Lookup
on thegoroutine
profile and then write that to a file withProfile.WriteTo
.Alternatively, native debuggers and tools such as
pstack
may be used but they generally lack the detail of Go stack dumps.This proposal is for Go to have a built-in signal handler that non-destructively writes a thread dump to
stderr
in response to a signal such asSIGUSR2
. This would be a behavior change that may cause unintended side effects for any programs that already have aSIGUSR2
handler.The text was updated successfully, but these errors were encountered: