jmeter 是j**a 應用,對於cpu和記憶體的消耗比較大,因此,當需要模擬數以千計的併發使用者時,使用單台機器模擬所有的併發使用者就有些力不從心,甚至會引起j**a記憶體溢位錯誤。為了讓jmeter工具提供更大的負載能力,jmeter短小精悍一有了使用多台機器同時產生負載的機制。
那麼,是如何實現多台負載機同時執行的呢?當然不會多個人坐在多台負載機面前,其實,我們通過單個jmeter 客戶端就可以控制多個遠端的jmeter伺服器,使它們同步的對伺服器進行壓力測試。
通過遠端執行jmeter,測試人員可以跨越多台低端計算機複製測試,這樣就可以模擬乙個比較大的伺服器壓力,乙個jmeter客戶端例項,理論上可以控制任意多的遠端jmeter例項,並通過他們收集測試資料。這樣一樣,就有了如下特性:
* 儲存測試取樣資料到本地機器
* 通過單台機器管理多個jmeter執行引擎。
* 沒有必要將測試計畫複製到每一台機器,jmeter gui客戶端會將它發往每一台jmeter伺服器。
* 每一台jmeter遠端伺服器都執行相同的測試計畫,jmeter不會在執行期間做負載均衡,每一台伺服器都會完整地執行測試計畫。
在1.4g hz~3ghz 的cpu 、1gb 記憶體的 jmeter 客戶端上,可以處理執行緒 100~300。但是web service 例外。xml處理是 cpu 運算密集的,會迅速消耗掉所有的cpu 。一般來說,以xml技術為核心的應用系統,其效能將是普通web 應用的 10%~25% 。另外,如果所有負載由一台機器產生,網絡卡和交換機埠都可能產生瓶頸,所以乙個jmeter 客戶端執行緒數不應超過 10 0 。
採用jmeter 遠端模式並不會比獨立執行相同數目的非gui 測試更耗費資源。但是,如果使用大量的jmeter 遠端伺服器,可能會導致客戶端過載,或者網路連線發生擁塞。
使用多台機器產生負載的操作步驟如下:
(1)在所有期望執行jmeter作為 負載生成器的機器上安裝jmeter, 並確定其中一台機器作為 controller ,其他的的機器作為agent 。然後執行所有 agent 機器上的jmeter-server 檔案(假定使用兩台機器192.168.0.100 和192.168.0.101 作為agent)
(2)在controller機器的jmeter的bin目錄下,找到jmeter.properties 檔案,編輯該檔案:
查詢:remote_hosts=127.0.0.1修改為:
remote_hosts=192.168.0.100:1099,192.168.0.101:1099
這裡要特別注意埠後,有些資料說明埠1644為jmeter的controller 和agent 之間進行通訊的預設rmi埠號,但是在測試時發現,設定為1644執行不成功,改成1099後執行通過。另外還要留意agent的機子是否開啟了防火牆等。
(3)啟動controller 機子上的jmeter應用,選擇選單「執行」--->「遠端啟動」,來分別啟動agent ,也可以直接選擇「遠端全部啟動」來將所有的agent啟動。
Jmeter分布式測試
很多時候,我們測試時,如果進行大資料量的併發測試時,單個電腦的 和記憶體可能無法承受,這個時候,我們需要進行乙個分布式的測試,比如10000個併發,使用三颱電腦來進行併發 jmeter提供了這種功能,你可以很輕鬆的實現jmeter的這種分布式測試 1 首先確何所有的電腦上都安裝jmeter 2 在所...
Jmeter分布式測試
很多時候,我們測試時,如果進行大資料量的併發測試時,單個電腦的 和記憶體可能無法承受,這個時候,我們需要進行乙個分布式的測試,比如10000個併發,使用三颱電腦來進行併發 jmeter提供了這種功能,你可以很輕鬆的實現jmeter的這種分布式測試 1 首先確何所有的電腦上都安裝jmeter 2 在所...
Jmeter分布式測試
使用分布式主要是為了緩解單台機器模擬使用者的壓力,這時候可以使用多個agent 即 準備 主機以及 的計算機上必須安裝 jmeter和jdk,並配置好環境變數 注意 controller以及agent的jmeter和jdk版本盡量保持一致 步驟1.進入控制器controller也就是本機,例如本機的...