golang 单元测试、性能测试、性能监控技术
go语言提供了强大的测试工具,下面举例简单介绍一下
go test 单元测试
例如对包helper下的util.go 进行单元测试,util.go 里主要包含两个功能,一个是对字符串进行sha1加密,一个是验证手机号码
- 编写测试文件
如果我们要测试验证手机号码功能是否正确,我们可以在该包下新建util_test.go文件,一般命名方式为 _test.go(为测试文件主文件名),测试函数以 Test函数(t *testing.T) 形式
util_test.go
然后cmd窗口下执行(注意将目录切换到当前目录,如果是windows系统,按住shift键同时单击右键,选择在此处打开命令窗口即可)
- 执行测试
go test
若要看到详细信息
go test -v
go test -bench=. 进行性能测试
在当前目录的命令行窗口执行
go test -bench=.
每次耗时 224599纳秒,执行10000次,总耗时2.38秒
生成cpu性能监控图
go用pprof包来做代码的性能监控包括:
net/http/pprof
runtime/pprof
如果你的go程序是用http包启动的web服务器,你想查看自己的web服务器的状态。这个时候就可以选择net/http/pprof。你只需要引入包_”net/http/pprof”
go run main.go 后就可以在浏览器中使用http://localhost:8080/debug/pprof/直接看到当前web服务的状态,包括cpu占用情况和内存使用情况等,例如
如果想以图形的形式展现,那么首先要安装Graphviz(图形工具,供go调用生成时序图,官网下载地址Graphviz,国内下载地址百度-Graphviz),想要生成cpu状态分析图,再开启一个命令窗口执行
go tool pprof http://localhost:8080/debug/pprof/profile
就会进入30秒的profile收集时间,在这段事件不断刷新点击http://localhost:8080/wechat 浏览器上的页面,尽量让cpu占用性能产生数据。
然后再光标闪烁处输入web命令,如果提示”dot not found,”原因可能是你没有安装Graphviz,如果已经安装了提示次错误,那么需要将Graphviz的bin目录加入到path路径即可
然后就会生成.svg 图形,会自动启动默认浏览器打开
如果你的go程序只是一个应用程序,比如计算阶乘,那么你就不能使用net/http/pprof包了,你就需要使用到runtime/pprof。具体做法就是用到pprof.StartcpuProfile和pprof.StopcpuProfile,具体使用请参考官方博文https://blog.golang.org/profiling-go-programs
var cpuprofile = flag.String("cpuprofile","","write cpu profile to file")
func main() {
flag.Parse()
if *cpuprofile != "" {
f,err := os.Create(*cpuprofile)
if err != nil {
log.Fatal(err)
}
pprof.StartcpuProfile(f)
defer pprof.StopcpuProfile()
}
...