Skip to content

Commit

Permalink
runtime/pprof: add section headers to Profile doc
Browse files Browse the repository at this point in the history
Adding explicit section headers makes it cleaner to split the profile
descriptions into multiple paragraphs, as there is now an explicit
transition from discussion of one profile type to the next.

For golang#14689.

Change-Id: Ifcff918367e91a165ee5f74423be3935b421972b
Reviewed-on: https://go-review.googlesource.com/c/go/+/547955
Reviewed-by: Rhys Hiltner <rhys@justin.tv>
Reviewed-by: Michael Knyszek <mknyszek@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Auto-Submit: Michael Pratt <mpratt@google.com>
  • Loading branch information
prattmic authored and ezz-no committed Feb 17, 2024
1 parent ac277e9 commit 638302d
Showing 1 changed file with 36 additions and 21 deletions.
57 changes: 36 additions & 21 deletions src/runtime/pprof/pprof.go
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,12 @@ import (
// These predefined profiles maintain themselves and panic on an explicit
// [Profile.Add] or [Profile.Remove] method call.
//
// The CPU profile is not available as a Profile. It has a special API,
// the [StartCPUProfile] and [StopCPUProfile] functions, because it streams
// output to a writer during profiling.
//
// # Heap profile
//
// The heap profile reports statistics as of the most recently completed
// garbage collection; it elides more recent allocation to avoid skewing
// the profile away from live data and toward garbage.
Expand All @@ -122,38 +128,47 @@ import (
// flags select which to display, defaulting to -inuse_space (live objects,
// scaled by size).
//
// # Allocs profile
//
// The allocs profile is the same as the heap profile but changes the default
// pprof display to -alloc_space, the total number of bytes allocated since
// the program began (including garbage-collected bytes).
//
// # Block profile
//
// The block profile tracks time spent blocked on synchronization primitives,
// such as [sync.Mutex], [sync.RWMutex], [sync.WaitGroup], [sync.Cond], and
// channel send/receive/select. Stack traces correspond to the location that
// blocked (for example, [sync.Mutex.Lock]). Sample values correspond to
// cumulative time spent blocked at that stack trace, subject to time-based
// sampling specified by [runtime.SetBlockProfileRate].
// channel send/receive/select.
//
// Stack traces correspond to the location that blocked (for example,
// [sync.Mutex.Lock]).
//
// Sample values correspond to cumulative time spent blocked at that stack
// trace, subject to time-based sampling specified by
// [runtime.SetBlockProfileRate].
//
// # Mutex profile
//
// The mutex profile tracks contention on mutexes, such as [sync.Mutex],
// [sync.RWMutex], and runtime-internal locks. Stack traces correspond to the
// end of the critical section causing contention. For example, a lock held for
// a long time while other goroutines are waiting to acquire the lock will
// report contention when the lock is finally unlocked (that is, at
// [sync.Mutex.Unlock]). Sample values correspond to the approximate cumulative
// time other goroutines spent blocked waiting for the lock, subject to
// event-based sampling specified by [runtime.SetMutexProfileFraction]. For
// example, if a caller holds a lock for 1s while 5 other goroutines are
// waiting for the entire second to acquire the lock, its unlock call stack
// will report 5s of contention.
//
// In the mutex profile, runtime-internal locks are always reported at the
// location "runtime._LostContendedRuntimeLock". More detailed stack traces for
// [sync.RWMutex], and runtime-internal locks.
//
// Stack traces correspond to the end of the critical section causing
// contention. For example, a lock held for a long time while other goroutines
// are waiting to acquire the lock will report contention when the lock is
// finally unlocked (that is, at [sync.Mutex.Unlock]).
//
// Sample values correspond to the approximate cumulative time other goroutines
// spent blocked waiting for the lock, subject to event-based sampling
// specified by [runtime.SetMutexProfileFraction]. For example, if a caller
// holds a lock for 1s while 5 other goroutines are waiting for the entire
// second to acquire the lock, its unlock call stack will report 5s of
// contention.
//
// Runtime-internal locks are always reported at the location
// "runtime._LostContendedRuntimeLock". More detailed stack traces for
// runtime-internal locks can be obtained by setting
// `GODEBUG=runtimecontentionstacks=1` (see package [runtime] docs for
// caveats).
//
// The CPU profile is not available as a Profile. It has a special API,
// the [StartCPUProfile] and [StopCPUProfile] functions, because it streams
// output to a writer during profiling.
type Profile struct {
name string
mu sync.Mutex
Expand Down

0 comments on commit 638302d

Please sign in to comment.