golang 性能测试

钟沐 · · 4294 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

格式:

func BenchmarkXxx(b *testing.B)

简单代码:

package examples

import (
    "io/ioutil"
    "net/http"
    "testing"
)
// 测试并发效率
func BenchmarkLoopsParallel(b *testing.B) {
    b.RunParallel(func(pb *testing.PB) { //并发
        for pb.Next() {
            resp, err := http.Get("http://10.10.200.128:8080/image?t=MDA")
            if err != nil {
                // handle error
            }

            cookies := resp.Cookies()
            verify_key := ""
            for _, v := range cookies {
                if v.Name == "VERIFY_KEY" {
                    verify_key = v.Value
                }
            }

            if err != nil {
                // handle error
            }
            defer resp.Body.Close()
            if verify_key == "" {
                b.Fail()
            }
        }
    })
}

运行

go test -bench="."

  • -parallel 50 设置并发
  • -count n 设置次数

testing.T

判定失败接口

  • Fail 失败继续
  • FailNow 失败终止

打印信息接口

  • Log 数据流 (cout 类似)
  • Logf format (printf 类似)
  • SkipNow 跳过当前测试
  • Skiped 检测是否跳过

综合接口产生:

  • Error / Errorf 报告出错继续 [ Log / Logf + Fail ]
  • Fatel / Fatelf 报告出错终止 [ Log / Logf + FailNow ]
  • Skip / Skipf 报告并跳过 [ Log / Logf + SkipNow ]

testing.B

首先 , testing.B 拥有testing.T 的全部接口。

  • SetBytes( i uint64) 统计内存消耗, 如果你需要的话。
  • SetParallelism(p int) 制定并行数目。
  • StartTimer / StopTimer / ResertTimer 操作计时器

testing.PB

  • Next() 接口 。 判断是否继续循环

注意点

  1. 文件需已test.go结尾

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:钟沐

查看原文:golang 性能测试

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

4294 次点击  ∙  1 赞  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传