使用 pprof 对 Web 应用进行性能调优

Go 性能调优
这部分内容参考自 q1mi 老师的技术博客,原文地址为:https://liwenzhou.com/posts/Go/pprof/

Go 性能优化

Go 语言项目中的性能优化主要在以下几个方面:

  • CPU Profile:报告程序的 CPU 使用情况,按照一定频率去采集应用程序在 CPU 和寄存器上的数据;
  • Memory Profile(Heap Profile):报告程序的内存使用情况;
  • Block Profiling:报告 Goroutines 不在运行状态的情况,可以用来分析和查找死锁等性能瓶颈;
  • Goroutine Profile:报告 Goroutines 的使用情况,有哪些 goroutine,它们的调用关系如何;

在 GIN 框架下使用 pprof

在 GIN 框架下可以使用github.com/gin-contrib/pprof,在代码中通过以下命令注册 pprof 相关路由:

pprof.Register(router)

以 bluebell 项目为例,在 routes.go 即路由文件当中,使用下述命令注册 pprof 相关路由:

pprof.Register(r) // 注册 pprof 相关路由

至此,当我们启动服务之后,访问/debug/pprof接口,即可获得类似下面的内容,我们先用 air 启动服务,再查看 /debug/pprof 下的内容:
在这里插入图片描述
单从这个页面的内容我们看不出什么内容,我们需要进一步使用 pprof 的可视化工具。

go tool pprof 命令

不管是工具型应用还是服务型应用,我们使用相应的 pprof 库获取数据之后,下一步都要对这些数据进行分析,我们可以使用 go tool pprof 命令行工具。

go tool pprof 最简单的用法:

go tool pprof [binary] [source]
  • binary 是应用的二进制文件,用来解析各种符号;
  • source 表示 profile 数据的来源,可以是本地文件,也可以是 http 地址;

注意事项:获取的 Profiling 数据是动态的,想要获得有效的数据,请保证应用处于较大的负载(比如使用go-wrk对服务接口进行压测的过程中获取 profiling)。否则,如果应用处于空闲状态,得到的结果意义不大。

结合 go-wrk 对 bluebell 的接口进行性能分析

现在我们将 pprof 和 go-wrk 相结合,在压测的过程中查看服务的性能。

首先启动 bluebell 项目,之后使用 go-wrk 开始压测:

go-wrk -t=8 -c=100 -n=10000 "http://127.0.0.1:8081/api/v1/posts"

之后我们使用:

go tool pprof http://127.0.0.1:8081/debug/pprof/profile

这条命令会查看 CPU 的使用情况。

然后在 pprof 的命令行输入 web,即可查看可视化图像(这一步需要先安装 Graphviz,在 windows 下还需要将这个工具的 bin 路径到环境变量):
在这里插入图片描述
至此,我们完成了在 GIN 框架当中使用 pprof 分析 web 应用性能的介绍。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值