2
2
mirror of https://github.com/octoleo/restic.git synced 2025-01-11 10:18:10 +00:00
restic/vendor/github.com/pkg/profile
2019-04-24 15:17:48 +02:00
..
.travis.yml Update dependencies 2019-04-24 15:17:48 +02:00
AUTHORS Vendor dependencies with dep 2017-07-23 14:25:38 +02:00
LICENSE Vendor dependencies with dep 2017-07-23 14:25:38 +02:00
mutex17.go Vendor dependencies with dep 2017-07-23 14:25:38 +02:00
mutex.go Vendor dependencies with dep 2017-07-23 14:25:38 +02:00
profile.go Update dependencies 2019-04-24 15:17:48 +02:00
README.md Vendor dependencies with dep 2017-07-23 14:25:38 +02:00
trace16.go Vendor dependencies with dep 2017-07-23 14:25:38 +02:00
trace.go Vendor dependencies with dep 2017-07-23 14:25:38 +02:00

profile

Simple profiling support package for Go

Build Status GoDoc

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"

func main() {
    defer profile.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"

func main() {
    // 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)
    ...
}

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.