Golang工具pprof无法正常工作-无论是何种分析目标,输出都是错误的。

9

我之前使用pprof工具没有问题,一切都很顺利——现在无论我如何进行分析,都会出现以下输出:

pprof的输出

在这个例子中,被分析的应用程序可能有40多个函数调用,而更复杂的应用程序也会产生类似的cpu和内存分析结果。

我正在尝试对所有的Web应用程序进行分析,每次分析持续一分钟,并使用wrk生成200,000,000多个请求,所有请求都返回数据和2xx响应。

pprof几天前突然停止工作,运行在osx yosemite上。为了解决这个问题,我最近升级到了el capitan,但结果仍然是一样的。

注意:这不仅仅是调用图——list命令或top命令的结果也类似,但应用程序本身工作正常。

    (pprof) top
269.97kB of 269.97kB total (  100%)
      flat  flat%   sum%        cum   cum%
  269.97kB   100%   100%   269.97kB   100%  
(pprof) 

我正在使用以下包:"github.com/davecheney/profile",与go v1.5.1一起使用。
为了清晰起见,这是我生成概要文件的步骤:
我将上述包导入main.go,并在我的主函数顶部放置以下内容:
defer profile.Start(profile.MemProfile).Stop()

我接着构建二进制文件并运行它:

go build -o orig /Users/danielwall/www/netlistener/application/adrequest.go /Users/danielwall/www/netlistener/application/cookie.go /Users/danielwall/www/netlistener/application/header.go /Users/danielwall/www/netlistener/application/lex.go /Users/danielwall/www/netlistener/application/main.go /Users/danielwall/www/netlistener/application/publisher_ids.go /Users/danielwall/www/netlistener/application/request.go /Users/danielwall/www/netlistener/application/response.go /Users/danielwall/www/netlistener/application/server.go /Users/danielwall/www/netlistener/application/sniff.go /Users/danielwall/www/netlistener/application/status.go /Users/danielwall/www/netlistener/application/transfer.go

./orig

我看到的输出如下所示:
2015/11/16 11:39:49 profile: memory profiling enabled, /var/folders/26/2sj70_sn72l_93j7tf6r07gr0000gn/T/profile614358295/mem.pprof

现在我从另一个终端运行该应用:

    wrk -d60 -c10 -H "X-Device: desktop" -H "X-Country-Code: GB" "http://localhost:8189/app?id=111&schema=xml2&ad_type=auto&url=http://test.com/&category=bob"
Running 1m test @ http://localhost:8189/app?id=111&schema=xml2&ad_type=auto&url=http://test.com/&category=bob
  2 threads and 10 connections
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency   414.09us    0.92ms  55.36ms   95.66%
    Req/Sec    17.57k     3.19k   22.59k    76.00%
  2097764 requests in 1.00m, 684.20MB read
Requests/sec:  34958.03
Transfer/sec:     11.40MB

60秒后,我回去查看我的个人资料:

^C2015/11/16 12:05:20 profile: caught interrupt, stopping profiles

go tool pprof /var/folders/26/2sj70_sn72l_93j7tf6r07gr0000gn/T/profile614358295/mem.pprof

有什么想法或者在哪里可以开始故障排除/解决这个问题吗?
欢迎任何帮助和建议。

1
展示一下你是如何制作配置文件的,特别是 profile.Start 的配置。 - Ainar-G
更新了上次运行中的所有内容 - 感谢您的关注。 - SwiftD
go build会捡起所有的测试文件,这就是为什么我要逐个列出它们的原因(我有一个脚本可以输出不是测试文件的文件列表(是否有更好的方法?)- 我认为你可能有解决方案,通过传递给pprof的选项中缺少二进制文件 - 让我检查一下。 - SwiftD
@Ainar-G 是的,缺少传递给pprof(用户muppetry)的二进制文件 - 感谢您的帮助 - 如果您将其提交为答案,我很乐意接受 :) - SwiftD
已回答。另外,我不太明白你所说的“go build会选择所有测试文件”的意思。除非你使用了go testgo build -tags test,否则它不会构建任何foo_test.go文件。 - Ainar-G
显示剩余2条评论
1个回答

10

您的go tool pprof调用缺少二进制本身。请按以下方式调用:

go tool pprof ./orig /path/to/profile.pprof

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接