性能測試之 Gatling

在應用程序上線以前,有多少人作過性能測試?git

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

可能大家不少人聽過 JMeter ,可是今天將介紹有競爭力的解決方案 —— Gatling 。它能生成豐富多彩的報告,包含測試案例中收集的全部指標。該功能彷佛比 JMeter 更好。docker

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

  • 負載測試(Load Testing):負載測試是一種主要爲了測試軟件系統是否達到需求文檔設計的目標,譬如軟件在必定時期內,最大支持多少併發用戶數,軟件請求出錯率等,測試的主要是軟件系統的性能。
  • 壓力測試(Stress Testing):壓力測試主要是爲了測試硬件系統是否達到需求文檔設計的性能目標,譬如在必定時期內,系統的cpu利用率,內存使用率,磁盤I/O吞吐率,網絡吞吐量等,壓力測試和負載測試最大的差異在於測試目的不一樣。

Gatling 簡介

Gatling 是一個功能強大的負載測試工具。它是爲易用性、可維護性和高性能而設計的。apache

開箱即用,Gatling 帶有對 HTTP 協議的出色支持,使其成爲負載測試任何 HTTP 服務器的首選工具。因爲核心引擎其實是協議不可知的,因此徹底能夠實現對其餘協議的支持,例如,Gatling 目前也提供JMS 支持。json

只要底層協議(如 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://www.jianshu.com/p/cdd9d29256c0

如但願瞭解更多,請關注微信公衆號

相關文章
相關標籤/搜索