Skip to content

pkg/profile

Repository files navigation

profile

Simple profiling support package for Go

Build StatusGoDoc

installation

go get github.com/pkg/profile 

usage

Enabling profiling in your application is as simple as one line at the top of your main function

import"github.com/pkg/profile"funcmain(){deferprofile.Start().Stop() ... }

options

What to profile is controlled by config value passed to profile.Start. By default CPU profiling is enabled.

import"github.com/pkg/profile"funcmain(){// p.Stop() must be called before the program exits to// ensure profiling information is written to disk.p:=profile.Start(profile.MemProfile, profile.ProfilePath("."), profile.NoShutdownHook) ...// You can enable different kinds of memory profiling, either Heap or Allocs where Heap// profiling is the default with profile.MemProfile.p:=profile.Start(profile.MemProfileAllocs, profile.ProfilePath("."), profile.NoShutdownHook) }

Several convenience package level values are provided for cpu, memory, and block (contention) profiling.

For more complex options, consult the documentation.

contributing

We welcome pull requests, bug fixes and issue reports.

Before proposing a change, please discuss it first by raising an issue.

About

Simple profiling for Go

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 13

Languages