Documentation ¶
Overview ¶
Package gostackparse parses goroutines stack traces as produced by panic() or debug.Stack() at ~300 MiB/s.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Frame ¶
type Frame struct { // Func is the name of the function, including package name, e.g. "main.main" // or "net/http.(*Server).Serve". Func string // File is the absolute path of source file e.g. // "/go/src/example.org/example/main.go". File string // Line is the line number of inside of the source file that was active when // the sample was taken. Line int }
Frame is a single call frame on the stack.
type Goroutine ¶
type Goroutine struct { // ID is the goroutine id (aka `goid`). ID int // State is the `atomicstatus` of the goroutine, or if "waiting" the // `waitreason`. State string // Wait is the approximate duration a goroutine has been waiting or in a // syscall as determined by the first gc after the wait started. Aka // `waitsince`. Wait time.Duration // LockedToThread is true if the goroutine is locked by a thread, aka // `lockedm`. LockedToThread bool // Stack is the stack trace of the goroutine. Stack []*Frame // FramesElided is true if the stack trace contains a message indicating that // additional frames were elided. This happens when the stack depth exceeds // 100. FramesElided bool // CreatedBy is the frame that created this goroutine, nil for main(). CreatedBy *Frame // Ancestors are the Goroutines that created this goroutine. // See GODEBUG=tracebackancestors=n in https://pkg.go.dev/runtime. Ancestor *Goroutine `json:"Ancestor,omitempty"` }
Goroutine represents a single goroutine and its stack after extracting it from the runtime.Stack() text format. See [1] for more info. [1] https://github.com/felixge/go-profiler-notes/blob/main/goroutine.md
func Parse ¶
Parse parses a goroutines stack trace dump as produced by runtime.Stack(). The parser is forgiving and will continue parsing even when encountering unexpected data. When this happens it will try to discard the entire goroutine that encountered the problem and continue with the next one. It will also return an error for every goroutine that couldn't be parsed. If all goroutines were parsed successfully, the []error slice is empty.