性能測試工具之Gatling


估計大部分開發者更多地關注功能測試,並且會提供一些單元測試和集成測試的用例。然而,有時候性能漏洞導致的影響比未發現的業務漏洞更嚴重,因為性能漏洞影響的是整個系統,而不僅僅是一個業務進程。

大部分的性能測試人員聽過 Jmeter ,但是今天將介紹有競爭力的解決方案 Gatling 。它能生成豐富多彩的報告,包含測試案例中收集的所有指標。該功能似乎比 Jmeter 更好。

在討論 Gatling 之前,先了解下理論知識,性能測試的兩種類型,負載測試和壓力測試:

1、負載測試(Load Testing):負載測試是一種主要為了測試軟件系統是否達到需求文檔設計的目標,譬如軟件在一定時期內,最大支持多少並發用戶數,軟件請求出錯率等,測試的主要是軟件系統的性能。

2、壓力測試(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、查看測試報告

全局報告

單個接口明細報告

 
 
參考:

https://blog.csdn.net/qq_32447301/article/details/88881445

https://blog.csdn.net/qq_32447301/article/details/88881445

https://www.jianshu.com/p/90afbd06b69a

https://blog.csdn.net/weixin_33786077/article/details/87948037


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2024 CODEPRJ.COM