JMeter使用了不一樣技術和協議,是一款能夠進行配置和執行負載測試、性能測試和壓力測試的工具。html
1.首先必須安裝java環境,最新版本Apache JMeter 3.0 須要JRE 1.7或者更高版本java
2.從http://jmeter.apache.org/download_jmeter.cgi下載最新版本的JMeter,將它解壓到例如D:\jmeter下(Windows),文件夾結構應該以下:python
D:. └─jmeter ├─bin ├─docs ├─extras ├─lib ├─licenses └─printable_docs
bin 目錄下存放的是可執行的程序、配置文件和日誌文件。mysql
jmeter.bat 是Jmeter的主運行程序,咱們經過這個程序來啓動JMeter。這個文件能夠被編輯,好比修改JVM參數:(注意 HEAP和PermSize之和不要超過物理內存的50%)web
set HEAP=-Xms512m -Xmx512msql
set PERM=-XX:PermSize=128m -XX:MaxPermSize=128m數據庫
jmeter-server.bat 是JMeter聯機負載測試的組件,若是須要作聯機測試,須要在負載機器上啓動該程序。apache
lib 目錄下包含ext、junit目錄及各類jar包json
docs 目錄下存放的是API文檔、默認的樣式文件及UI圖片等。windows
3.而後你就能夠進入到D:\jmeter\bin(對於Windows用戶),執行jmeter.bat,能夠看到JMeter GUI的啓動界面:
本文使用聚合數據的老黃曆接口爲例,api接口文檔:https://www.juhe.cn/docs/api/id/65
測試計劃描述了執行測試過程當中JMeter的執行過程和步驟,一個完整的測試計劃包括一個或者多個線程組(Thread Groups)、邏輯控制(Logic Controller)、實例產生控制器(Sample Generating Controllers)、偵聽器(Listener)、定時器(Timer)、比較(Assertions)、配置元素(Config Elements)。
打開JMeter時,它已經創建一個默認的測試計劃,一個JMeter應用的實例只能創建或者打開一個測試計劃。這裏,咱們假設須要JMeter模擬五個請求者(也就是五個線程),每一個請求者連續請求兩次
這一步,咱們將向測試計劃中增長相關負載設置,使Jmeter知道咱們須要模擬五個請求者,每一個請求者在測試過程當中連續請求兩次。詳細步驟以下:
1. 選中可視化界面中左邊樹的Test Plan節點,單擊右鍵,選擇Add->Threads(Users)->Thread Group,界面右邊將會出現他的設置信息框。
2. Thread Group有三個和負載信息相關的參數:
Number of Threads: 設置發送請求的用戶數目
Ramp-up period: 初始化設置用戶數所有啓動的時間,單位是秒。好比你的用戶數(線程)是5,而這個參數是10,則表明10s內5個用戶所有啓動,即每2秒新啓動一個用戶數。
Loop Count: 請求發生的重複次數
根據咱們演示例子的設計,咱們應該將Number of Threads設置爲5,Ramp-up period設置爲0(也就是同時併發請求),不選中forever,在Loop Count後面的輸入框中輸入2
設置後的屏幕截圖以下:
實際的測試工做每每是針對同一個服務器上Web應用展開的,因此Jmeter提供了這樣一種設置, 在默認Http屬性設置須要被測試服務器的相關屬性,之後的http請求設置中就能夠忽略這些相同參數的設置,減小設置參數錄入的時間。
設置默認http屬性步驟:
1. 選中可視化界面中左邊樹的Test Plan節點,單擊右鍵,選擇Add->Config Element->HTTP Request Defaults,界面右邊將會出現他的設置信息框。
2.默認http屬性的主要參數說明以下:
protocal: 發送測試請求時使用的協議
server name or ip:被測試服務器的ip地址或者名字
path: 默認的起始位置
port number: 服務器提供服務的端口號
設置後的屏幕截圖以下:
如今咱們須要增長http請求了,他也是咱們測試的內容主體部分。你能夠經過下面的步驟來增長性的http請求:
1. 選中可視化界面中左邊樹的Thread Group節點,單擊右鍵,選擇Add->Sampler->HTTP Request,界面右邊將會出現他的設置信息框。
2. 增長的屬性中有發送http時方法的選擇,你能夠選擇爲get或者post。
咱們如今增長兩個http 請求,由於咱們設置了默認的http屬性,因此和默認http屬性中相同的屬性再也不重複設置。根據接口文檔,設置請求參數date和key(自行申請)
設置後的屏幕截圖以下:
增長listener是爲了記錄測試信息而且可使用Jmeter提供的可視化界面查看測試結果,裏面有好幾種結果分析方式可供選擇,你能夠根據本身習慣的分析方式選擇不一樣的結果顯示方式,咱們這裏同時使用表格和樹的形式來查看和分析測試結果。你能夠經過下面的步驟來增長listener:
1. 選中可視化界面中左邊樹的Thread Group節點,單擊右鍵,選擇Add->Listener->View Results Tree,界面右邊將會出現他的設置信息和結果顯示框。
2. 選中可視化界面中左邊樹的Thread Group節點,單擊右鍵,選擇Add->Listener->View Results in Table,界面右邊將會出現他的設置信息和結果顯示框。
方式一:經過單擊菜單欄run -> Start開始執行測試計劃
方式二:在左邊樹的Thread Group節點,單擊右鍵,選擇Start 開始執行測試線程組
View Results in Table:
View Results Tree:
在使用Jemeter作壓力測試的時候,每每須要參數化。這個時候咱們就可使用CSV Data Set Config來實現。
1.首先經過Test Plan或者Thread Group的Add->Config Element->CSV Data Set Config添加,本實例中將date參數化。
2.建立D:\date.txt,以下:
3.CSV Data Set Config各個參數的簡要說明:
FileName: 即同目錄下csv文件的名稱
File Encoding: 默認爲ANSI
Varible Names: 定義文本文件中的參數名,參數之間逗號分隔.定義後可在腳本在以Shell變量的一樣的方式引用
Allow Quoated data: 雙引號相關
Recycle on EOF: 設置爲True後,容許循環取值
Stop Thread on EOF: 當Recycle on EOF爲false而且Stop Thread on EOF爲true,則讀完csv文件中的記錄後,中止運行
Sharing Mode: 設置是否線程共享
設置CVS參數,設置好屏幕截圖以下
從新運行,檢查View Results Tree 中的Request,可發現各個請求中的date已實現參數化
在這一節中,咱們建立50個用戶,每次執行2條sql語句,重複執行100次。總請求數爲 (50 Users)x(2 requests)x(repeat 100 times)=10,000 JDBC requests.
1.本實例使用 MySQL 數據庫驅動。將數據庫驅動(ex.mysql-connector-java-5.1.40-bin.jar)下載存放到 JMeter 安裝目錄下的./lib 目錄中,如本教程安裝目錄D:\jmeter\lib
數據庫驅動下載地址:http://dev.mysql.com/downloads/connector/j/
2.本實例使用MySQL數據庫,MySQL數據庫安裝見教程:《MYSQL 免安裝版(windows 7/64)》
本實例使用本地數據庫test中的test表。
SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for test -- ---------------------------- DROP TABLE IF EXISTS `test`; CREATE TABLE `test` ( `name` varchar(255) DEFAULT NULL, `age` int(11) DEFAULT NULL, `sex` varchar(255) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of test -- ---------------------------- INSERT INTO `test` VALUES ('Cherish', '29', 'F'); INSERT INTO `test` VALUES ('Cherish', '27', 'F'); INSERT INTO `test` VALUES ('Milton', '28', 'G'); INSERT INTO `test` VALUES ('Milton', '26', 'G');
使用JMeter建立任何測試計劃,首先第一步是建立線程組。在線程組中能夠設定模擬用戶數、請求發送頻率、總共發送請求數。
選中測試計劃->右鍵->選擇Add->Threads(Users)->Thread Group 配置後以下:
首先,配置JDBC鏈接信息,選中線程組 JDBC Users,右鍵,選擇
Variable Name:myDatabase (這個配置,在後面requests請求中,要使用到,表示調用該份數據庫配置)
Database URL:jdbc:mysql://localhost:3306/test
JDBC Driver class: com.mysql.jdbc.Driver
Username: 數據庫用戶名
Password: 數據庫鏈接密碼
其餘選項能夠默認,配置後以下:
而後配置JDBC請求,選中線程組 JDBC Users,右鍵,選擇
在測試計劃面板中,導入mysql-connector-java-5.1.40-bin.jar 以下
選中線程組 JDBC Users,右鍵,選擇
運行線程組後,測試結果以下:
本實例中,咱們建立5個虛擬用戶,每次訪問發起一個請求,重複執行兩次。總請求數爲 (5 Users)x(1 requests)x(repeat 2 times)=10 HTTP requests。
在本實例中,咱們使用了以前教程《Python 開發與測試 Webservice(SOAP)》中介紹的方法,建立並啓動webservice服務端。
選中測試計劃,右鍵,選擇 Add-> Config Element -> User Defined Variable ,配置以下:
選中測試計劃,右鍵,選擇 Add -> Config Element -> HTTP Request Defaults,配置以下
選中測試計劃,右鍵,選擇 Add -> Threads(Users) -> Thread Group,配置以下:
選中線程組 Number of Users,右鍵,選擇 Add -> Sampler -> HTTP Request,配置以下:
<?xml version="1.0" encoding="UTF-8"?> <SOAP-ENV:Envelope xmlns:ns0="spyne.examples.hello.soap" xmlns:ns1="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"> <SOAP-ENV:Header/> <ns1:Body> <ns0:say_hello> <ns0:name>Milton</ns0:name> <ns0:times>1</ns0:times> </ns0:say_hello> </ns1:Body> </SOAP-ENV:Envelope>
選中HTTP Request,右鍵,選擇 Add -> Config Element -> HTTP Header Manager ,配置以下:
選中HTTP Request,右鍵,選擇 Add -> Assertions -> Response Assertion,配置以下:
選中測試計劃,右鍵,選擇
最權威最詳細的教程,請見JMeter官網:http://jmeter.apache.org/