這兩天接到一個任務(wù),要測試一個服務(wù)器的性能,客戶要求向數(shù)據(jù)庫內(nèi) 1000/s(每插入一千條數(shù)據(jù)) 的處理能力,當時腦子賭賽了,想的是用LR來進行,由于LR接觸不深,只知道LR實現(xiàn)參數(shù)化的時候可以調(diào)用數(shù)據(jù)庫里面的數(shù)據(jù),往里面大批量的插入數(shù)據(jù),以前沒試過。
翻閱了一下資料,找一到了一篇《一種特殊的數(shù)據(jù)庫性能測試》,大概思路是:通過編寫一java程序來循環(huán)插入數(shù)據(jù),編寫一個批處理文件來調(diào)用java程序。再通過LR的system()函數(shù)來調(diào)用批處理文件來進行壓力測試。但是對于我這種菜鳥來說,好多細節(jié)不懂。比如那個批處理就讓我很為難。呵呵。
其實,通過jmeter很簡單就可以完成,可以參考我以前的一篇文章《jmeter創(chuàng)建數(shù)據(jù)庫(MySql)測試》。
前提條件:一個數(shù)據(jù)庫:test 數(shù)據(jù)庫下面有一張表:user 表中有兩個字段:username、passworld 。
要求:往數(shù)據(jù)庫內(nèi)大批量插入數(shù)據(jù),1000/s
其實和之前的方法一樣,為了簡單,我還是把截圖貼出來吧。
1.
創(chuàng)建一個測試計劃,將我們所使用的數(shù)據(jù)庫驅(qū)動包導(dǎo)入。

2.
添加一個線程組,并設(shè)置我們的虛擬用戶數(shù)、啟動時間、和循環(huán)次數(shù)

3.
創(chuàng)建一個線程,并在線程下面,創(chuàng)建一個JDBC Connection Configuration ,設(shè)置相關(guān)信息。

4.
創(chuàng)建一個JDBC Request.我們需要對數(shù)據(jù)庫做插入操作。(詳細設(shè)置,看截圖上的說明)

5.
添加監(jiān)聽器,我們這里選擇添加“圖形結(jié)果”和“查看結(jié)果樹”,點擊菜單欄上的“啟動”--->運行。
查看我們的運行結(jié)果。


在測試的過程中,通過數(shù)據(jù)庫命令,可以查看當前數(shù)據(jù)庫插入了多少數(shù)據(jù)
