热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

gotest自带有三种测试:今天主要是写一下基准测试也就是我们的性能测试实践相关。基准测试是测量一个

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  
 

然后在命令行输入如下:

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 的环境变量才开始压测哦!

运行启动如图所示:

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

image

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

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

image

2. 线程数的配置:

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

image

3. 建立HTTP请求接口:

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

image

4. 建立监控器 数据展示

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

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

image

聚合报告数据说明:

来看如图所示的数据:

中文版

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

image

英文版

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

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 试试呢。

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

image

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

具体分析原因:

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

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

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

image

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

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

image

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


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 我们


推荐阅读
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • FeatureRequestIsyourfeaturerequestrelatedtoaproblem?Please ... [详细]
  • ASP.NET2.0数据教程之十四:使用FormView的模板
    本文介绍了在ASP.NET 2.0中使用FormView控件来实现自定义的显示外观,与GridView和DetailsView不同,FormView使用模板来呈现,可以实现不规则的外观呈现。同时还介绍了TemplateField的用法和FormView与DetailsView的区别。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ... [详细]
  • Imtryingtofigureoutawaytogeneratetorrentfilesfromabucket,usingtheAWSSDKforGo.我正 ... [详细]
author-avatar
Era_zhou
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有