標籤:
JMeter是apache的jakarta上面的項目,用於軟體的壓力測試(Load Test),不但可以對HTTP,也可以對資料庫(通過JDBC)、FTP、Web Service、Java 對象等等進行壓力測試。最近,在我們的項目中使用到了它。我們的項目是基於BEA Weblogic的一個J2EE項目,在一個Domain中部署了3個J2EE應用,這樣在客戶使用的過程中出現了WebLogic記憶體記憶體回收的問題。 於是我們配置了WebLogic叢集,並將其中的某些應用分開部署,並使用了JMeter進行了效能測試。從而為應用程式的效能診斷提供了必要的依據。
基本概念
JMeter的測試計劃(Test Plan)呈樹狀結構,樹裡面有多種元素類型,樹狀結構的元素之間有的是有繼承關係的(其原理有點類似log4j)。下面簡述一下元素類型:
1、ThreadGroup
顧名思義就是線程組,測試必須有一個ThreadGroup元素作為基礎(否則就沒有測試線程在跑了),這個元素可以配置跑多少個線程、每個線程迴圈多少次,所有線程數的總啟動時間(Ramp-up period)等等。
2、Controller
包括Logical Controller和Sampler,前者用來作一些邏輯上的控制,例如輪換、條件、迴圈等等。Sampler就是真正“幹活”的“取樣器”,例如“HTTP Request”,就是拿來執行一個HTTP請求的。
3、Listener
Listener對請求過程進行監聽,可以簡單理解為擷取結果的東東。例如Simple Data Writer,可以把結果寫到一個文字檔裡(其實所有Listener都可以寫資料到檔案裡),還有View Results in Table,就是把結果顯示在表格裡。
4、 Timer
用來控制執行流程中的時間延遲等功能。
5、 Assertion
斷言,加到Sampler裡面可以對返回的結果進行判斷,例如判斷HTTP返回結果裡面是否含有某個字串。如果斷言為真,JMeter會標記請求為成功,否則標記為失敗。
6、 Configuration Element
配置用的元素,很有用。由於測試計劃是樹狀和有繼承關係的,可以在高層次指定一個Configuration Element,低層次的相關Sampler如果沒有顯式地指定配置,就繼承高層次的配置資訊。(跟log4j很像吧?)
7、 Pre-Processor/Post-Processor Elements
用來在Sampler運行前和運行後作一些預先處理和後處理工作的。例如動態修改請求的參數(預先處理),從返回資訊裡面提取資訊(後處理)等等。
要提醒一下的是jmeter根據當前系統的locale顯示菜單的語言,為了方便想設定回英文的話,可以修改jmeter.properties檔案,設定language=en
JMeter的使用
#啟動
大家可以到通過http://apache.linuxforum.net/dist/jakarta/jmeter/binaries/jakarta-jmeter-1.9.1.zip下載JMeter的release版本,然後將下載的.zip檔案解壓縮到C:/JMeter(後面的文章中將使用%JMeter%來引用這個目錄)目錄下。現在,請使用%JMeter%/bin下面的jmeter.bat批次檔來啟動JMeter的可視化介面,下面的工作都將在這個可視化介面介面上進行操作。下面的圖片是JMeter的可視化介面的螢幕。
圖一: JMeter開啟時的螢幕
# 建立測試計劃(Test Plan)
測試計劃描述了執行測試過程中JMeter的執行過程和步驟,一個完整的測試計劃包括一個或者多個線程組(Thread Groups)、邏輯控制(Logic Controller)、執行個體產生控制器(Sample Generating Controllers)、接聽程式(Listener)、定時器(Timer)、比較(Assertions)、配置元素(Config Elements)。開啟JMeter時,它已經建立一個預設的測試計劃,一個JMeter應用的執行個體只能建立或者開啟一個測試計劃。現在我們開始填充一個測試計劃的內容,這個測試計劃向一個jsp檔案和一個servlet發出請求,我們需要JMeter類比五個要求者(也就是五個線程),每個要求者連續請求兩次,下面的章節介紹了詳細的操作步驟。
# 增加負載資訊設定
這一步,我們將向測試計劃中增加相關負載設定,是Jmeter知道我們需要類比五個要求者,每個要求者在測試過程中連續請求兩次。詳細步驟如下:
1. 選中可視化介面中左邊樹的Test Plan節點,單擊右鍵,選擇Add‘Thread Group,介面右邊將會出現他的設定資訊框。
2. Thread Group有三個和負載資訊相關的參數:
Number of Threads: 設定發送請求的使用者數目
Ramp-up period: 每個請求發生的總時間間隔,單位是秒。比如你的請求數目是5,而這個參數是10,那麼每個請求之間的間隔就是10/5,也就是2秒
Loop Count: 請求發生的重複次數,如果選擇後面的forever(預設),那麼 請求將一直繼續,如果不選擇forever,而在輸入框中輸入數字,那麼請求將重複 指定的次數,如果輸入0,那麼請求將執行一次。
據我們示範例子的設計,我們應該將Number of Threads設定為5,Ramp-up period設定為0(也就是同時並發請求),不選中forever,在Loop Count後面的輸入框中輸入2,設定後的螢幕如下:
圖二:設定好參數的Thread Group
# 增加預設Http屬性(可選)
實際的測試工作往往是針對同一個伺服器上Web應用展開的,所以Jmeter提供了這樣一種設定, 在預設Http屬性設定需要被測試伺服器的相關屬性,以後的http請求設定中就可以忽略這些相同參數的設定,減少設定參數錄入的時間。我們這裡將採用這 種屬性。你可以通過下面的步驟來設定預設http屬性:
1. 選中可視化介面中左邊樹的Test Plan節點,單擊右鍵,選擇Add‘config element‘http request defaults,介面右邊將會出現他的設定資訊框。
2. 預設http屬性的主要參數說明如下:
protocal:發送測試請求時使用的協議
server name or ip:被測試伺服器的ip地址或者名字
path: 預設的起始位置。比如將path設定為/jmeter,那麼所有的http請求的url中都將增加/jmeter路徑。
port number: 伺服器提供服務的連接埠號碼
我們的測試計劃將針對原生Web伺服器上的Web應用進行測試,所以protocal應該是http,ip使用localhost,因為這個web 應用發布的context路徑是/jmeter,所以這裡的path設定為/jmeter,因為使用Tomcat伺服器,所以port number是8080。
# ?增加Http請求
現在我們需要增加http請求了,他也是我們測試的內容主體部分。你可以通過下面的步驟來增加性的http請求:
1. 選中可視化介面中左邊樹的Thread Group節點,單擊右鍵,選擇Add‘sampler‘http request,介面右邊將會出現他的設定資訊框。
2. 他的參數和2.5中介紹的http屬性差不多,增加的屬性中有發送http時方法的選擇,你可以選擇為get或者post。
我們現在增加兩個http 請求,因為我們設定了預設的http屬性,所以和預設http屬性中相同的屬性不再重複設定。設定後的螢幕如下:
圖三:設定好的jsp測試請求
圖四:設定好的Servlet測試請求(帶參數)
# 增加Listener
增加listener是為了記錄測試資訊並且可以使用Jmeter提供的可視化介面查看測試結果,裡面有好幾種結果分析方式可供選擇,你可以根據自己 習慣的分析方式選擇不同的結果顯示方式,我們這裡使用表格的形式來查看和分析測試結果。你可以通過下面的步驟來增加listener:
1. 選中可視化介面中左邊樹的Test Plan節點,單擊右鍵,選擇Add‘listener‘view result in table,介面右邊將會出現他的設定資訊和結果顯示框。
2. 你可以設定介面上面的filename屬性設定將測試結果儲存到某個檔案中介面下面將使用表格顯示測試結果,表格的第一列sampleno顯示請求執行的 順序和編號,url顯示 請求發送的目標,sample-ms列顯示這個請求完成耗費的時間,最後的success列顯示改請求是否成功執行。介面的最 下面你還可以看到一些統計資訊,最關心的應該是Average吧,也就是相應的平均時間。?
# 開始執行測試計劃
現在你可以通過單擊功能表列run -> Start開始執行測試計劃了。下面是該測試計劃的結果圖:
圖五:結果顯示
JMeter用於進行供能或者效能測試,通過使用JMeter提供的供能,我們可以可視化的制定測試計劃:包括規定使用什麼樣的負載、測試什麼內容、傳入的參數,同時,他提供了好多種圖形化的測試結果顯示方式,使我們能夠簡單的開始測試工作和分析測試結果。
基於JMeter對J2EE應用程式進行效能測試