強大的負(fù)載測試工具之Gatling
在應(yīng)用程序上線之前,有多少人做過性能測試?
估計大部分開發(fā)者更多地關(guān)注功能測試,并且會提供一些單元測試和集成測試的用例。然而,有時候性能漏洞導(dǎo)致的影響比未發(fā)現(xiàn)的業(yè)務(wù)漏洞更嚴(yán)重,因為性能漏洞影響的是整個系統(tǒng),而不僅僅是一個業(yè)務(wù)進程。
可能你們很多人聽過 JMeter ,但是今天將介紹有競爭力的解決方案 —— Gatling 。它能生成豐富多彩的報告,包含測試案例中收集的所有指標(biāo)。該功能似乎比 JMeter 更好。
在討論 Gatling 之前,先了解下理論知識,性能測試的兩種類型,負(fù)載測試和壓力測試:
負(fù)載測試(Load Testing):負(fù)載測試是一種主要為了測試軟件系統(tǒng)是否達到需求文檔設(shè)計的目標(biāo),譬如軟件在一定時期內(nèi),***支持多少并發(fā)用戶數(shù),軟件請求出錯率等,測試的主要是軟件系統(tǒng)的性能。
壓力測試(Stress Testing):壓力測試主要是為了測試硬件系統(tǒng)是否達到需求文檔設(shè)計的性能目標(biāo),譬如在一定時期內(nèi),系統(tǒng)的cpu利用率,內(nèi)存使用率,磁盤I/O吞吐率,網(wǎng)絡(luò)吞吐量等,壓力測試和負(fù)載測試***的差別在于測試目的不同。
Gatling 簡介
Gatling 是一個功能強大的負(fù)載測試工具。它是為易用性、可維護性和高性能而設(shè)計的。
開箱即用,Gatling 帶有對 HTTP 協(xié)議的出色支持,使其成為負(fù)載測試任何 HTTP 服務(wù)器的***工具。由于核心引擎實際上是協(xié)議不可知的,所以完全可以實現(xiàn)對其他協(xié)議的支持,例如,Gatling 目前也提供JMS 支持。
只要底層協(xié)議(如 HTTP)能夠以非阻塞的方式實現(xiàn),Gatling 的架構(gòu)就是異步的。這種架構(gòu)可以將虛擬用戶作為消息而不是專用線程來實現(xiàn)。因此,運行數(shù)千個并發(fā)的虛擬用戶不是問題。
Gatling 快速入門實踐
1、創(chuàng)建 Spring Boot 應(yīng)用,提供 RESTful API,以供測試
https://github.com/ChinaSilence/gatling-test.git
如果有自己測試的 Web 應(yīng)用可以忽略本步驟!
2、啟動數(shù)據(jù)庫
Github 中的示例代碼依賴了 PostgresSQL,所以要先啟動數(shù)據(jù)庫,最簡單的方式當(dāng)然是用 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 環(huán)境
安裝 scala 插件
安裝 scala SDK
4、編寫性能測試腳本
每一個 Gatling 測試都要繼承 Simulation 類,在里面你可以使用Gatling Scala DSL 來聲明一個場景列表。這里的目標(biāo)是運行 30 個客戶端,同時發(fā)送 1000 次請求。首先,客戶端通過調(diào)用 POST /persons 方法將添加數(shù)據(jù)到數(shù)據(jù)庫中;然后,嘗試通過調(diào)用 GET /persons/{id} 方法使用 id 來查詢數(shù)據(jù)。
- 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 應(yīng)用
6、運行測試腳本
配置 Maven 插件參數(shù)
- <build>
- <plugins>
- <plugin>
- <groupId>io.gatling</groupId>
- <artifactId>gatling-maven-plugin</artifactId>
- <version>${gatling-plugin.version}</version>
- <configuration>
- <!-- 測試腳本 -->
- <simulationClass>com.anoyi.test.ApiGatlingSimulationTest</simulationClass>
- <!-- 結(jié)果輸出地址 -->
- <resultsFolder>/Users/admin/code/gatling</resultsFolder>
- </configuration>
- </plugin>
- </plugins>
- </build>
執(zhí)行測試
- mvn gatling:execute
7、查看測試報告
全局報告
單個接口明細(xì)報告
【本文為51CTO專欄作者“翟永超”的原創(chuàng)稿件,轉(zhuǎn)載請通過51CTO聯(lián)系作者獲取授權(quán)】