介紹
Gatling是一款功能強(qiáng)大的負(fù)載測試工具。它的設(shè)計易于使用,可維護(hù)性和高性能。
開箱即用,Gatling提供了對HTTP協(xié)議的出色支持,使其成為負(fù)載測試HTTP服務(wù)器的首選工具。
只要底層協(xié)議(如HTTP)可以以非阻塞方式實(shí)現(xiàn),Gatling的體系結(jié)構(gòu)就是異步的。這種架構(gòu)允許我們將虛擬用戶實(shí)現(xiàn)為消息而不是專用線程,這使得它們非常便宜。因此,運(yùn)行數(shù)千個并發(fā)虛擬用戶不是問題。(和jmeter區(qū)別點(diǎn))
Gatling是一款基于Scala 開發(fā)的高性能服務(wù)器性能測試工具,它主要用于對服務(wù)器進(jìn)行負(fù)載等測試,并分析和測量服務(wù)器的各種性能指標(biāo)。Gatling主要用于測量基于HTTP的服務(wù)器,比如Web應(yīng)用程序,RESTful服務(wù)等,除此之外它擁有以下特點(diǎn):
- 支持Akka Actors 和 Async IO,從而能達(dá)到很高的性能
- 支持實(shí)時生成Html動態(tài)輕量報表,從而使報表更易閱讀和進(jìn)行數(shù)據(jù)分析
- 支持DSL腳本,從而使測試腳本更易開發(fā)與維護(hù)
- 支持錄制并生成測試腳本,從而可以方便的生成測試腳本
- 支持導(dǎo)入HAR(Http Archive)并生成測試腳本
- 支持Maven,Eclipse,IntelliJ等,以便于開發(fā)
- 支持Jenkins,以便于進(jìn)行持續(xù)集成
- 支持插件,從而可以擴(kuò)展其功能,比如可以擴(kuò)展對其他協(xié)議的支持
- 開源免費(fèi)
獲取Gatling
官網(wǎng)下載即可。
(需要使用JDK1.8,有可能會存在版本問題,
我的版本為java version "1.8.0_111"
)
目錄結(jié)構(gòu)如圖。簡單來說:
bin: gatling也就兩種組件-錄制的組件和運(yùn)行的組件;這個目錄里面有兩種腳本,一個是運(yùn)行recorder的,也就是錄制組件啟動腳本;一個是運(yùn)行組件的啟動腳本;
conf: 放配置文件的目錄。一般情況下你想要修改一些運(yùn)行參數(shù),都可來這里搞定;
lib: 里面是一些jar包,gatling的運(yùn)作全靠他們了;我們僅作為使用者暫時不必去理會;
results: 測試報告目錄;
target: 你啟動運(yùn)行組件后,gatling會為你編譯好所有的.scala腳本,而編譯后的class文件就會在這里;
user-files: 存放你錄制后的.scala腳本;
總的來說,用gatling做一次簡單的測試步驟如下(忽略細(xì)節(jié)):
- 在bin里打開recorder.bat(GUI)
- 錄制后,在user-files里針對剛錄制好的.scala文件作你想要的修改
- 在bin里打開gatling.bat(控制臺)
- 選擇你要運(yùn)行哪一個腳本,并運(yùn)行 ,運(yùn)行完成后,在results目錄下查看結(jié)果
實(shí)踐
1.打開recorder
錄制看一下腳本是啥樣。所以打開了recorder
還可以使用以下選項(xiàng)進(jìn)行設(shè)置:
- (Follow Redirects? checked)關(guān)注重定向?檢查
- (Automatic Referers? checked)自動參考?檢查
- (Black list first filter strategy selected)選擇黑名單第一個過濾策略,黑名單過濾器中的。。css,。。js和。*。ico
2. 設(shè)置一下瀏覽器代理
打開瀏覽器,設(shè)置代理端口和上面保持一致。
3. 開始錄制
回到recorder中,點(diǎn)一下Start,隨后在瀏覽器中模仿真實(shí)用戶的場景。完成場景播放后,單擊StopRecorder界面。
腳本默認(rèn)會存在定義的輸出文件夾gatling\user-files\simulations
里面,名稱為類的名字。
默認(rèn)所有的.scala腳本都放置在\user-files\simulations中某一個包的根目錄下,一旦項(xiàng)目變得龐大,是會變的不容易進(jìn)行維護(hù)的。
可以考慮以包的形式來存放腳本
做法,在
\user-files\simulations
里面創(chuàng)建包名存放腳本。
4. 查看腳本
查看user-files/simulations/computerdatabase
在名稱下的Gatling安裝文件夾中生成BasicSimulation.scala
。(這個是官方自帶的腳本)
對稍微懂點(diǎn)代碼的測試人員,這個腳本都是簡單易懂的:
httpProtocol中的BlackList描述了你將不會錄制針對css,js和ico文件的請求。錄制到了幾個請求頭header。
scenario("HomePage")定義了這個場景的名稱。默認(rèn)以你的類名來命名,當(dāng)然你可以改,比如改成SinaHomePage。修改這個名字只會影響你運(yùn)行該腳本后在報告中看到的名字。
這個龐大的場景“HomePage”賦給了變量scn。當(dāng)然,你也可以把他賦值給另一個變量叫做SinaUsers,看起來更為貼切,代碼更易懂。
setUp(scn)就是運(yùn)行這個場景的主函數(shù)。
inject為這個場景注入一些用戶。這里atOnceUsers代表一次性一個用戶來做這個操作——因?yàn)閯偛配浿茣r就是這種情況.
5. 運(yùn)行腳本
bin\gatling.bat
運(yùn)行后短暫等待一下,gatling會編譯\user-files\simulations
里面存在的所有腳本:
可以看到已經(jīng)編譯成功。前面6個是gatling自帶的腳本。編號6是后續(xù)添加修改的腳本。
cmd中敲入6,然后回車三下(后面的simulation id和description留空,所以直接回車)。可以看到gatling開始運(yùn)行。
6. 報告一覽
要針對gatling的report進(jìn)行詳盡透徹的分析,并正確評價系統(tǒng),甚至找出性能瓶頸
HAR文件生成腳本
Gatling的Recorder提供了HAR Converter的功能。
這樣產(chǎn)生的腳本會更加精準(zhǔn)。
高級用法
分層設(shè)計
類似于Selenium的PageObject模式。
借用官網(wǎng)解釋
在我們的場景中,我們有三個獨(dú)立的過程
- 搜索:按名稱搜索模型
- 瀏覽:瀏覽模型列表
- 編輯:編輯給定的模型
將提取這些鏈并將它們存儲到對象中。對象是原生的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就很相似了,借用面對對象的思想,把公用的封裝為對象,需要使用的時候就調(diào)用對象里面的方法。
可以使用這些可重用的業(yè)務(wù)流程重寫我們的場景
val scn = scenario("Scenario Name").exec(Search.search, Browse.browse, Edit.edit)