性能测试之 Gatling

更多内容关注微信公众号:fullstack888

介绍

Gatling是一款功能强大的负载测试工具。它的设计易于使用,可维护性和高性能。

开箱即用,Gatling提供了对HTTP协议的出色支持,使其成为负载测试HTTP服务器的首选工具。

只要底层协议(如HTTP)可以以非阻塞方式实现,Gatling的体系结构就是异步的。这种架构允许我们将虚拟用户实现为消息而不是专用线程,这使得它们非常便宜。因此,运行数千个并发虚拟用户不是问题。(和jmeter区别点)

Gatling是一款基于Scala 开发的高性能服务器性能测试工具,它主要用于对服务器进行负载等测试,并分析和测量服务器的各种性能指标。Gatling主要用于测量基于HTTP的服务器,比如Web应用程序,RESTful服务等,除此之外它拥有以下特点:

  • 支持Akka Actors 和 Async IO,从而能达到很高的性能

  • 支持实时生成Html动态轻量报表,从而使报表更易阅读和进行数据分析

  • 支持DSL脚本,从而使测试脚本更易开发与维护

  • 支持录制并生成测试脚本,从而可以方便的生成测试脚本

  • 支持导入HAR(Http Archive)并生成测试脚本

  • 支持Maven,Eclipse,IntelliJ等,以便于开发

  • 支持Jenkins,以便于进行持续集成

  • 支持插件,从而可以扩展其功能,比如可以扩展对其他协议的支持

  • 开源免费


获取Gatling

官网下载即可。
(需要使用JDK1.8,有可能会存在版本问题,
我的版本为java version "1.8.0_111")

09dfcb3cdca1d8781518dad646d3405b.png

目录结构如图。简单来说:

  • bin: gatling也就两种组件-录制的组件和运行的组件;这个目录里面有两种脚本,一个是运行recorder的,也就是录制组件启动脚本;一个是运行组件的启动脚本;

  • conf: 放配置文件的目录。一般情况下你想要修改一些运行参数,都可来这里搞定;

  • lib: 里面是一些jar包,gatling的运作全靠他们了;我们仅作为使用者暂时不必去理会;

  • results: 测试报告目录;

  • target: 你启动运行组件后,gatling会为你编译好所有的.scala脚本,而编译后的class文件就会在这里;

  • user-files: 存放你录制后的.scala脚本;

总的来说,用gatling做一次简单的测试步骤如下(忽略细节):

da331bb43d102e77b269a5fbe7b13fa1.png

  1. 在bin里打开recorder.bat(GUI)

  2. 录制后,在user-files里针对刚录制好的.scala文件作你想要的修改

  3. 在bin里打开gatling.bat(控制台)

  4. 选择你要运行哪一个脚本,并运行 ,运行完成后,在results目录下查看结果

实践

1.打开recorder

录制看一下脚本是啥样。所以打开了recorder

3467c216f1934b0d526f5105471a9148.png

还可以使用以下选项进行设置:

  • (Follow Redirects? checked)关注重定向?检查

  • (Automatic Referers? checked)自动参考?检查

  • (Black list first filter strategy selected)选择黑名单第一个过滤策略,黑名单过滤器中的。。css,。。js和。*。ico

2. 设置一下浏览器代理

打开浏览器,设置代理端口和上面保持一致。

ea90fcef44b8f7efad7f6a5b66153fa3.png

3. 开始录制

回到recorder中,点一下Start,随后在浏览器中模仿真实用户的场景。完成场景播放后,单击StopRecorder界面。

脚本默认会存在定义的输出文件夹gatling\user-files\simulations里面,名称为类的名字。

默认所有的.scala脚本都放置在\user-files\simulations中某一个包的根目录下,一旦项目变得庞大,是会变的不容易进行维护的。
可以考虑以包的形式来存放脚本

做法,在\user-files\simulations里面创建包名存放脚本。

4. 查看脚本

查看user-files/simulations/computerdatabase在名称下的Gatling安装文件夹中生成BasicSimulation.scala。(这个是官方自带的脚本)

官方已经解释的很明确

对稍微懂点代码的测试人员,这个脚本都是简单易懂的:

  • httpProtocol中的BlackList描述了你将不会录制针对css,js和ico文件的请求。录制到了几个请求头header。

  • scenario("HomePage")定义了这个场景的名称。默认以你的类名来命名,当然你可以改,比如改成SinaHomePage。修改这个名字只会影响你运行该脚本后在报告中看到的名字。

  • 这个庞大的场景“HomePage”赋给了变量scn。当然,你也可以把他赋值给另一个变量叫做SinaUsers,看起来更为贴切,代码更易懂。

  • setUp(scn)就是运行这个场景的主函数。

  • inject为这个场景注入一些用户。这里atOnceUsers代表一次性一个用户来做这个操作——因为刚才录制时就是这种情况.

5. 运行脚本

bin\gatling.bat

运行后短暂等待一下,gatling会编译\user-files\simulations里面存在的所有脚本:

5f086a3a5dc11def7d9554ce4689cb71.png

可以看到已经编译成功。前面6个是gatling自带的脚本。编号6是后续添加修改的脚本。

cmd中敲入6,然后回车三下(后面的simulation id和description留空,所以直接回车)。可以看到gatling开始运行。

8f36c54aba34abc4136e2544cbe33046.png

6. 报告一览

084480915e317de49253aaa6619f2fdb.png

c4b41b81243ea7df3dbf183f41750097.png

368481cf19408820f20307e048e54f31.png

f035de25c6f5a3b4d6d5a8901fb01459.png

要针对gatling的report进行详尽透彻的分析,并正确评价系统,甚至找出性能瓶颈

HAR文件生成脚本

Gatling的Recorder提供了HAR Converter的功能。

34d7492538da633c336b01a9363d8524.png

这样产生的脚本会更加精准。

高级用法

分层设计

类似于Selenium的PageObject模式。

借用官网解释
在我们的场景中,我们有三个独立的过程

  • 搜索:按名称搜索模型

  • 浏览:浏览模型列表

  • 编辑:编辑给定的模型

将提取这些链并将它们存储到对象中。对象是原生的Scala单例。

object Search {


  val search = exec(http("Home") // let's give proper names, as they are displayed in the reports
    .get("/"))
    .pause(7)
    .exec(http("Search")
      .get("/computers?f=macbook"))
    .pause(2)
    .exec(http("Select")
      .get("/computers/6"))
    .pause(3)
}


object Browse {
  val browse = ???
}


object Edit {
  val edit = ???
}

和Java就很相似了,借用面对对象的思想,把公用的封装为对象,需要使用的时候就调用对象里面的方法。

可以使用这些可重用的业务流程重写我们的场景

val scn = scenario("Scenario Name").exec(Search.search, Browse.browse, Edit.edit)

- END -

往期回顾

作业帮应用框架实践

ShardingJDBC分库分表完美扩容

服务端高并发分布式架构演进之路

架构师图谱之微服务&消息队列

ab25f32016e6952f2a5d5e982b1c75cc.png

更多内容关注公众号:fullstack888

技术交流,请加微信: jiagou6688 ,备注:Java,拉你进架构群

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值