go 1.5跟踪命令 [英] The go 1.5 trace command

查看:180
本文介绍了go 1.5跟踪命令的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

Go 1.5发布说明称,


新的go tool trace命令可以显示由新跟踪生成的程序跟踪运行时基础设施。

这真的很刺激,我想知道更多。但是它在


The Go 1.5 release note says,

The new "go tool trace" command enables the visualisation of program traces generated by new tracing infrastructure in the runtime.

This is really exciting, and I want to know more about it. But its official document at https://golang.org/cmd/trace/ is really dry.

Found that Rob Pike complained about it, requesting that "shortly after the 1.5 release, there should be a blog post about the feature."

If anyone has posted/spotted such a blog, please add a link here. Or, if you like to answer directly here, it is also welcome as well.

Thanks

解决方案

There are two ways you can generate trace files.

Method 1

  1. Add following line at the start of your program

    f, err := os.Create(time.Now().Format("2006-01-02T150405.pprof"))
    if err != nil {
        panic(err)
    }
    defer f.Close()
    
    if err := trace.Start(f); err != nil {
        panic(err)
    }
    defer trace.Stop()
    

  2. build the program

    go build

  3. Run your program (for example ./myprogram)
  4. Run go trace.

    go tool trace myprogram 2015-08-21T115354.pprof

Method 2

  1. Write a testing function utilizing testing package.
  2. Run Test with trace flag

    go test -trace trace.out

  3. Run trace tool with generated .test and .out file

    go tool trace pkg.test trace.out

In both cases your browser will open something like this

这篇关于go 1.5跟踪命令的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆