一、JMeter 介紹
近期公司要做jmeter調研,將性能測試推廣到全部測試組,便一邊學習一邊做記錄。
Apache JMeter是100%純JAVA桌面應用程序,是一款優秀的開源性能測試工具,被設計為用於測試客戶端/服務端結構的軟件(例如web應用程序)。它可以用來測試靜態和動態資源的性能,例如:靜態文件,Java Servlet,CGI Scripts,Java Object,數據庫和FTP服務器等等。JMeter可用於模擬大量負載來測試一台服務器,網絡或者對象的健壯性或者分析不同負載下的整體性能。
同時,JMeter可以幫助你對你的應用程序進行回歸測試。通過你創建的測試腳本和assertions來驗證你的程序返回了所期待的值。為了更高的適應性,JMeter允許你使用正則表達式來創建這些assertions.
JMeter與LoadRunner比較
JMeter 是一款開源(有着典型開源工具特點:界面不美觀)測試工具,雖然與LoadRunner相比有很多不足,比如:它結果分析能力沒有LoadRunner詳細;很它的優點也有很多:
- 開源,他是一款開源的免費軟件,使用它你不需要支付任何費用,
- 小巧,相比LR的龐大(最新LR11將近4GB),它非常小巧,不需要安裝,但需要JDK環境,因為它是使用java開發的工具。
- 功能強大,jmeter設計之初只是一個簡單的web性能測試工具,但經過不段的更新擴展,現在可以完成數據庫、FTP、LDAP、WebService等方面的測試。因為它的開源性,當然你也可以根據自己的需求擴展它的功能。
兩者最大的區別:jmeter不支持IP欺騙,而LR支持。
JMeter缺點
使用JMeter無法驗證JS程序,也無法驗證頁面UI,所以要須要和Selenium配合來完成Web2.0應用的測試。
二、安裝及下載
這里附一個最新的jmeter官網下載地址:http://jmeter.apache.org/download_jmeter.cgi 。該鏈接是4.0版本的jmeter安裝包。
jmeter本身不需要安裝,只需要配置好JDK環境,然后在在jmeter文件中的bin文件中打開jmeter.bat文件即可
1)JMeter下載
一般開放原代碼軟件都會有兩個版本發布: Source Distribution 和 Binary Distribution ,
Source 是源代碼版,你需要自己編譯成可執行軟件。
Binaries是可執行版,直接下載解壓就可以拿來用的,他已經給你編譯好的版本,下載Binaries/apache-jmeter-4.0.zip即可。
2)JMeter安裝
1. http://jmeter.apache.org/下載最新版本的JMeter,解壓文件到任意目錄
2. 安裝JDK,配置環境變量JAVA_HOME.
3. 系統要求:JMeter4 需要JDK1.8及以上的版本支持運行
4. JMeter可以運行在如下操作系統上:Unix,Windows和Open VMS.
5. 避免在一個有空格的路徑安裝JMeter,這將導致遠程測試出現問題。
3)JMeter插件安裝
1. 插件下載地址: http://jmeter-plugins.org/downloads/all/
2. 插件下載后解壓:找到JMeterPlugins-Extras.jar,把JMeterPlugins-Extras.jar放到apache-jmeter-4.0\lib\ext目錄。
三、JMeter 運行
1. 進入bin目錄運行jmeter.bat啟動jmeter
注意:打開的時候會有兩個窗口,JMeter的命令窗口和JMeter的圖形操作界面,不可以關閉命令窗口。
2. JMeter的classpath:
如果你想添加其他JAR文件到JMeter的classpath中,你必須復制他們到lib目錄中;
如果你開發了一個JMeter特定組件或有效的jar文件,復制到lib目錄下的ext目錄中。
3. 打開之后顯示的是中文,如果你想使用其他語言,比如英文,那么通過菜單選項→選擇語言→英文即可,當然轉為中文也是同樣操作。
四、JMeter 測試計划元件
4.0版本以下的jmeter,打開Jmeter頁面:包括測試計划+工作台。
4.0版本的jmeter,只有測試計划。工作台放在了 測試計划-添加-非測試元件;
1、Test Plan (測試計划):用來描述一個性能測試,包含與本次性能測試所有相關的功能。也就說本的性能測試的所有內容是於基於一個計划的。
右鍵單擊“測試計划”彈出菜單:
注意:
“函數測試模式”復選框,如果被選擇,它會使Jmeter記錄來自服務器返回的每個取樣的數據。如果你在測試監聽器中選擇一個文件,這個數據將被寫入文件。如果你嘗試一個較小的測試來保證Jmeter配置正確並且你的服務器正在返回期望的結果,這是很有用的。這樣做的后果就是這個文件會快速的增大,並且Jmeter的效率會影響。
如果不記錄數據到文件,這個選項就沒有不同了。
2、Threads (Users)線程 用戶
雖然有三個添加線程組的選項,名字不一樣, 創建之后,其界面是完全一樣的。之前的版本只有一個線程組的名字。現在多一個setUp theread Group 與terDown Thread Group
1) setup thread Group
一種特殊類型的ThreadGroup的,可用於執行預測試操作。這些線程的行為完全像一個正常的線程組元件。不同的是,這些類型的線程執行測試前進行定期線程組的執行。
setUp Thread Group類似於lr(loadrunner)的init.可用於執行預測試操作。
2) teardown thread group.
一種特殊類型的ThreadGroup的,可用於執行測試后動作。這些線程的行為完全像一個正常的線程組元件。不同的是,這些類型的線程執行測試結束后執行定期的線程組。
tearDown Thread Group類似於lr的end.可用於執行測試后動作。
3) thread group(線程組).
這個就是我們通常添加運行的線程。通俗的講一個線程組,,可以看做一個虛擬用戶組,線程組中的每個線程都可以理解為一個虛擬用戶。線程組中包含的線程數量在測試執行過程中是不會發生改變的。
線程組:
名稱:就如字面意思,起個有意義的名字就行
注釋:
線程數:這里選擇5
Ramp-Up Period:單位是秒,默認時間是1秒。它指定了啟動所有線程所花費的時間,比如,當前的設定表示“在1秒內啟動5個線程,每個線程的間隔時間為0.2秒”。如果你需要Jmeter立即啟動所有線程,將此設定為0即可
循環次數:表示每個線程執行多少次請求。
3、測試片段(Test Fragment)
測試片段元素是控制器上的一個種特殊的線程組,它在測試樹上與線程組處於一個層級。它與線程組有所不同,因為它不被執行,除非它是一個模塊控制器或者是被控制器所引用時才會被執行。
控制器
JMeter有兩種類型的控制器:取樣器(sample)和邏輯控制器(Logic Controller),用這些原件來驅動處理一個測試。
4、取樣器(Sampler)
右鍵線程組,取樣器(Sampler)是性能測試中向服務器發送請求,記錄響應信息,記錄響應時間的最小單元,JMeter 原生支持多種不同的sampler , 如 HTTP Request Sampler 、 FTP Request Sampler 、TCP Request Sampler 、 JDBC Request Sampler 等,每一種不同類型的 sampler 可以根據設置的參數向服務器發出不同類型的請求。
在Jmeter的所有Sampler中,Java Request Sampler與BeanShell Requst Sampler是兩種特殊的可定制的Sampler.
5、邏輯控制器(Logic Controller)
右鍵線程組,邏輯控制器,包括兩類無件,一類是用於控制test plan 中 sampler 節點發送請求的邏輯順序的控制器,常用的有 如果(If)控制器 、 switch Controller 、Runtime Controller、循環控制器等。另一類是用來組織可控制 sampler 來節點的, 如 事務控制器、吞吐量控制器。
6、配置元件(Config Element)
右鍵測試計划,配置元件(config element)用於提供對靜態數據配置的支持。CSV Data Set config (CSV數據文件設置)可以將本地數據文件形成數據池 (Data Pool),而對應於HTTP Request Sampler和 TCP Request Sampler等類型的配制元件則可以修改 Sampler的默認數據。
例如,HTTP Cookie Manager 可以用於對 HTTP Request Sampler 的 cookie 進行管理。
HTTP 請求默認值不會觸發Jmeter發送http請求,而只是定義HTTP請求的默認屬性。
7、定時器(Timer)
定時器(Timer)用於操作之間設置等待時間,等待時間是性能測試中常用的控制客戶端QPS的手段。類似於LoadRunner里面的“思考時間”。 JMeter 定義了Bean Shell Timer、Constant Throughput Timer、固定定時器等不同類型的Timer。
8、前置處理器(Per Processors)
前置處理器用於在實際的請求發出之前對即將發出的請求進行特殊處理。例如,HTTP URL重寫修復符則可以實現URL重寫,當RUL中有sessionID 一類的session信息時,可以通過該處理器填充發出請求的實際的sessionID 。
9、后置處理器(Post Processors)
后置處理器是用於對Sampler 發出請求后得到的服務器響應進行處理。一般用來提取響應中的特定數據(類似LoadRunner測試工具中的關聯概念)。例如,XPath Extractor 則可以用於提取響應數據中通過給定XPath 值獲得的數據;正則表達式提取器,則可以提取響應數據中通過正則表達式獲得的數據。
10、斷言(Assertions)
斷言用於檢查測試中得到的相應數據等是否符合預期,斷言一般用來設置檢查點,用以保證性能測試過程中的數據交互是否與預期一致。
11、監聽器(Listener)
這個監聽器可不是用來監聽系統資源的元件。它是用來對測試結果數據進行處理和可視化展示的一系列元件。 圖形結果、查看結果樹、聚合報告、用表格察看結果都是我們經常用到的元件。
五、工作台
1)4.0以下版本:
工作台為測試中不使用的測試元素提供一個臨時存的位置,目的是提供復制/粘貼或者其他目的。保存測試計划工作台的內容默認不會保存除非選擇”save workbench”(保存工作台)選項。工作台可以被獨立的保存,比如在選中工作台節點時,右鍵–選中部分保存為。
2)4.0版本
在測試中我們可能需要暫時更改一些組件,可以把一些需要更改的組件保存在工作台中,測試完成后再恢復,但是切記:不能退出jmeter.一旦退出jmeter,工作台中的內容就會消失。
工作台只能包含
- HTTP(S) Test Script Recorder
- HTTP Mirror Server
- Property Display
1、工作台-非測試元件-Property Display,此元件相當於是jmeter.properties的GUI。
六、幫助
http://jmeter.apache.org/usermanual/component_reference.html
最好的幫助是:菜單-“幫助”-“幫助”。
到此,我們已經簡單了解了jmeter的基本組成原件,我們后序的測試工作也就是使用這些元件來完成測試任務。