强大的负载测试工具之Gatling

在应用程序上线之前,载测有多少人做过性能测试?试工

估计大部分开发者更多地关注功能测试,并且会提供一些单元测试和集成测试的载测用例。然而,试工有时候性能漏洞导致的载测影响比未发现的业务漏洞更严重,因为性能漏洞影响的试工是整个系统,而不仅仅是载测一个业务进程。

可能你们很多人听过 JMeter ,试工但是载测今天将介绍有竞争力的解决方案 —— Gatling 。它能生成丰富多彩的试工报告,包含测试案例中收集的载测所有指标。该功能似乎比 JMeter 更好。试工

在讨论 Gatling 之前,载测先了解下理论知识,试工性能测试的载测两种类型,负载测试和压力测试:

负载测试(Load Testing):负载测试是一种主要为了测试软件系统是否达到需求文档设计的目标,譬如软件在一定时期内,***支持多少并发用户数,软件请求出错率等,测试的高防服务器主要是软件系统的性能。

压力测试(Stress Testing):压力测试主要是为了测试硬件系统是否达到需求文档设计的性能目标,譬如在一定时期内,系统的cpu利用率,内存使用率,磁盘I/O吞吐率,网络吞吐量等,压力测试和负载测试***的差别在于测试目的不同。

Gatling 简介

Gatling 是一个功能强大的负载测试工具。它是为易用性、可维护性和高性能而设计的。

开箱即用,Gatling 带有对 HTTP 协议的出色支持,使其成为负载测试任何 HTTP 服务器的***工具。由于核心引擎实际上是协议不可知的,所以完全可以实现对其他协议的支持,站群服务器例如,Gatling 目前也提供JMS 支持。

只要底层协议(如 HTTP)能够以非阻塞的方式实现,Gatling 的架构就是异步的。这种架构可以将虚拟用户作为消息而不是专用线程来实现。因此,运行数千个并发的虚拟用户不是问题。

Gatling 快速入门实践

1、创建 Spring Boot 应用,提供 RESTful API,以供测试

https://github.com/ChinaSilence/gatling-test.git

如果有自己测试的 Web 应用可以忽略本步骤!

2、启动数据库

Github 中的示例代码依赖了 PostgresSQL,所以要先启动数据库,最简单的方式当然是用 Docker 咯:

docker run -d \   --name postgres \   -e POSTGRES_DB=gatling \   -e POSTGRES_USER=gatling \   -e POSTGRES_PASSWORD=gatling123 \   -p 5432:5432 \   postgres 

3、在 IDEA 中安装 scala 环境

安装 scala 插件

安装 scala SDK

4、编写性能测试脚本

每一个 Gatling 测试都要继承 Simulation 类,在里面你可以使用Gatling Scala DSL 来声明一个场景列表。这里的目标是运行 30 个客户端,同时发送 1000 次请求。源码下载首先,客户端通过调用 POST /persons 方法将添加数据到数据库中;然后,尝试通过调用 GET /persons/{ id} 方法使用 id 来查询数据。

class ApiGatlingSimulationTest extends Simulation {    val scn = scenario("AddAndFindPersons").repeat(1000, "n") {      exec(       http("AddPerson-API")         .post("http://localhost:8080/persons")         .header("Content-Type", "application/json")         .body(StringBody("""{ "firstName":"John${ n}","lastName":"Smith${ n}","birthDate":"1980-01-01", "address": { "country":"pl","city":"Warsaw","street":"Test${ n}","postalCode":"02-200","houseNo":${ n}}}"""))         .check(status.is(200))     ).pause(Duration.apply(5, TimeUnit.MILLISECONDS))   }.repeat(1000, "n") {      exec(       http("GetPerson-API")         .get("http://localhost:8080/persons/${ n}")         .check(status.is(200))     )   }   setUp(scn.inject(atOnceUsers(30))).maxDuration(FiniteDuration.apply(10, "minutes")) } 

5、运行 Spring Boot 应用

6、运行测试脚本

配置 Maven 插件参数

<build>     <plugins>         <plugin>             <groupId>io.gatling</groupId>             <artifactId>gatling-maven-plugin</artifactId>             <version>${ gatling-plugin.version}</version>             <configuration>             <!-- 测试脚本 -->                  <simulationClass>com.anoyi.test.ApiGatlingSimulationTest</simulationClass>             <!-- 结果输出地址 -->                 <resultsFolder>/Users/admin/code/gatling</resultsFolder>             </configuration>         </plugin>     </plugins> </build> 

执行测试

mvn gatling:execute 

7、查看测试报告

全局报告

单个接口明细报告

【本文为专栏作者“翟永超”的原创稿件,转载请通过联系作者获取授权】

戳这里,看该作者更多好文

IT科技
上一篇:如果你的潜在终端必须是这个米(域名),那么潜在终端并不多,也没有硬通货,那么你的域名应该在终端有兴趣购买时出售。否则,你可能得自己留着吃。
下一篇:用户邮箱的静态密码可能已被钓鱼和同一密码泄露。在没有收到安全警报的情况下,用户在适当的时间内不能更改密码。在此期间,攻击者可以随意输入帐户。启用辅助身份验证后,如果攻击者无法获取移动电话动态密码,他将无法进行身份验证。这样,除非用户的电子邮件密码和手机同时被盗,否则攻击者很难破解用户的邮箱。