golang基准测试Benchmark和Jmeter压测实践

golang的性能测试Benchmark

go test 自带有三种测试:

  • 功能测试(单元测试)
  • 基准测试 (性能测试)
  • 实例测试 (举例测试)

今天主要是写一下基准测试也就是我们的性能测试实践相关。

基准测试是测量一个程序在固定工作负载下的性能。

在Go语言中,基准测试函数和普通测试函数写法类似,但是以Benchmark为前缀名,并且带有一个testing.B类型的参数;testing.B参数除了提供和*testing.T类似的方法,还有额外一些和性能测量相关的方法。

它还提供了一个整数N,用于指定操作执行的循环次数。


func BenchmarkAdapter_GetReport(b *testing.B) {
    a := &Adapter{
        Server: "127.0.0.1:9094/tenant",
    }
    for i := 0; i < b.N; i++ {
        b.ReportAllocs() // 这里可以直接调用 ReportAllocs 方法,就省去了再命令行中输入 -benchmem ,用于查看内存分配的大小和次数
        _, _ = a.GetReport("devices", "appsinfo", "")
    }
}

然后在命令行输入如下:

go test -bench=GetReport

又或者直接填入测试函数名:

 go test -bench=BenchmarkAdapter_GetReport

最终显示数据如下:

goos: darwin
goarch: amd64
pkg: safeuem/report/service/adapter
BenchmarkAdapter_GetReport-4         500       2351618 ns/op       20770 B/op        301 allocs/op
PASS
ok      safeuem/report/service/adapter  2.741s
  • BenchmarkAdapter_GetReport-4 :

这里的-4中的4 表示最大 P 数量,最大 P 数量相当于可以同时运行 goroutine 的逻辑 CPU 的最大个数。这里的逻辑 CPU,也可以被称为 CPU 核心,但它并不等同于计算机中真正的 CPU 核心,只是 Go 语言运行时系统内部的一个概念,代表着它同时运行 goroutine 的能力。

对应 golang 就是 GOMAXPROCS 的值。这个你可以自行设置,可以通过调用 runtime.GOMAXPROCS 函数改变最大P数量,也可以在命令行 go test 加入 -cpu=2 。

  • 500 2351618 ns/op

显示每次调用 GetReport 函数花费 2.351618毫秒 ,是执行 500次 的平均时间。

1s=1000ms=1000000us=1000000000ns

因为基准测试驱动器开始时并不知道每个基准测试函数运行所花的时间,它会尝试在真正运行基准测试前先尝试用较小的N运行测试来估算基准测试函数所需要的时间,然后推断一个较大的时间保证稳定的测量结果

  • 20770 B/op 301 allocs/op

表示平均500此种,每次分配了内存为 20770 B(字节) = 20.28KB = 0.0198MB 和 每次调用分配了 301次

1MB=1024KB

1KB=1024B

  • 2.741s

表示测试总耗时。

小提示:

其实这里的总耗时,其实默认是1s,当测试次数逐渐递增到时间刚好超过1s 时测试就会停止,并显示测试,这里是500次。

当然如果你的本身的测试函数运行一次就已经大于了1s,为了提高测试的精确性,你可以在命令行输入 :

go test -bench=GetReport -benchtime=5s



jmeter 压力测试

首先要安装 请看链接不多说

如果下载页面进不去 移步到此处下载即可

注意 : 一定要配置好java的环境变量才开始压测哦!

运行启动如图所示:

image

1. 你可以开始配置要测试的http接口:

image

2. 线程数的配置:

image

3. 建立HTTP请求接口:

image

4. 建立监控器 数据展示

可以建立三个查看,一般我建立聚合报告看看就可以了。

image

聚合报告数据说明:

来看如图所示的数据:

中文版

image

英文版

image

这里我的线程数改变了 2 。

  • Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值

  • Samples:表示你这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100,每个用户只迭代一次就是10了。我这里自然是 2.

  • Average:平均响应时间(单位ms,1s=1000ms)——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,也可以以Transaction 为单位显示平均响应时间

  • Median:中位数,也就是 50% 用户的响应时间

  • 90% Line:90% 用户的响应时间

  • Min:最小响应时间

  • Max:最大响应时间

  • Error%:本次测试中出现错误的请求的数量/请求的总数

  • Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),如果你的接口超过了每秒请求一次就会按照每分钟展示, 当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数

  • Received KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec

  • Send KB/Sec: 每秒向服务器端接发送的数据量。

所以如图中的线程数为2的测试中,平均每次响应时间为 554 毫秒相当于半秒,吞吐量为每秒处理了 1.9 次,额。。。很渣的性能。

因为这个接口本来就没有高并发场景要求,而且里面有个比较麻烦的递归查询操作很消耗性能的。

加大压力进行测试

那么如果出现较多的访问该接口,较高并发访问性能是如何的呢。

来个小 50 试试呢。

image

好吧,这个接口性能确实很差。。。平均一个接口处理要6s的时间。

具体分析原因:

  • 一个是递归耗性能
  • 另一个应该是Cassandra数据库I/O是性能瓶颈,pool可以从10调大到100试试。

将Cassandra连接池pool调为100压测数据

image

将线程数设置为200压测数据如下:

image

果然性能处理要好很多了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容