Go   发布时间:2022-04-09  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了golang 单元测试、性能测试、性能监控技术大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

golang 单元测试、性能测试、性能监控技术

go语言提供了强大的测试工具,下面举例简单介绍一下

  • go test 单元测试
  • go test -bench=. 性能测试
  • go tool pprof 性能监控

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()
    }
    ...

链接

大佬总结

以上是大佬教程为你收集整理的golang 单元测试、性能测试、性能监控技术全部内容,希望文章能够帮你解决golang 单元测试、性能测试、性能监控技术所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。