2017-01-25 13:53682人閱讀評論(0)收藏舉報
分類:
Jmeter(6)
版權(quán)聲明:本文為博主原創(chuàng)文章饵史,未經(jīng)博主允許不得轉(zhuǎn)載唠梨。
Jmeter?是Java應(yīng)用,對于CPU和內(nèi)存的消耗比較大山林,因此紊馏,當(dāng)需要模擬數(shù)以千計的并發(fā)用戶時,使用單臺機器模擬所有的并發(fā)用戶就有些力不從心恋沃,甚至?xí)餔AVA內(nèi)存溢出錯誤橄镜。為了讓jmeter工具提供更大的負載能力,jmeter短小精悍一有了使用多臺機器同時產(chǎn)生負載的機制窝爪。
那么弛车,是如何實現(xiàn)多臺負載機同時運行的呢?當(dāng)然不會多個人坐在多臺負載機面前蒲每,一喊開始,大家同時啟動jmeter喻括。這種方式很笨邀杏,也很難達到真正的同步。其實,我們通過單個jmeter?客戶端就可以控制多個遠程的jmeter服務(wù)器望蜡,使它們同步的對服務(wù)器進行壓力測試唤崭。
通過遠程運行jmeter,測試人員可以跨越多臺低端計算機復(fù)制測試脖律,這樣就可以模擬一個比較大的服務(wù)器壓力谢肾,一個jmeter客戶端實例,理論上可以控制任意多的遠程jmeter實例小泉,并通過他們收集測試數(shù)據(jù)仑嗅。這樣一樣鸳兽,就有了如下特性:
*???保存測試采樣數(shù)據(jù)到本地機器
*???通過單臺機器管理多個jmeter執(zhí)行引擎。
*???沒有必要將測試計劃復(fù)制到每一臺機器,jmeter?GUI客戶端會將它發(fā)往每一臺jmeter服務(wù)器嗜浮。
*???每一臺jmeter遠程服務(wù)器都執(zhí)行相同的測試計劃,jmeter不會在執(zhí)行期間做負載均衡漠畜,每一臺服務(wù)器都會完整地運行測試計劃锭沟。
在1.4G?Hz~3GHz?的CPU?、1GB?內(nèi)存的?JMeter?客戶端上配喳,可以處理線程?100~300酪穿。但是Web?Service?例外。XML處理是?CPU?運算密集的晴裹,會迅速消耗掉所有的CPU?昆稿。一般來說,以XML技術(shù)為核心的應(yīng)用系統(tǒng)息拜,其性能將是普通Web?應(yīng)用的?10%~25%?溉潭。另外,如果所有負載由一臺機器產(chǎn)生少欺,網(wǎng)卡和交換機端口都可能產(chǎn)生瓶頸喳瓣,所以一個JMeter?客戶端線程數(shù)不應(yīng)超過?100。
采用JMeter?遠程模式并不會比獨立運行相同數(shù)目的非GUI?測試更耗費資源赞别。但是畏陕,如果使用大量的JMeter?遠程服務(wù)器,可能會導(dǎo)致客戶端過載仿滔,或者網(wǎng)絡(luò)連接發(fā)生擁塞惠毁。
使用多臺機器產(chǎn)生負載的操作步驟如下:
(1)在所有期望運行jmeter作為?負載生成器的機器上安裝jmeter,?并確定其中一臺機器作為?controller?崎页,其他的的機器作為agent?鞠绰。
(2)?運行所有?agent?機器上的jmeter-server?文件(假定使用兩臺機器192.168.9.99 和192.168.9.130 作為agent)
(3)在controller機器的jmeter的bin目錄下,找到j(luò)meter.properties?文件飒焦,編輯該文件:
查找:
remote_hosts=127.0.0.1
修改為:
remote_hosts=192.168.9.99:1099,192.168.9.130:1099
這里要特別注意端口后蜈膨,有些資料說明端口1644為jmeter的controller?和agent?之間進行通信的默認RMI端口號,但是在測試時發(fā)現(xiàn),設(shè)置為1644運行不成功翁巍,改成1099后運行通過驴一。另外還要留意agent的機子是否開啟了防火墻等。
(4)啟動controller?機子上的jmeter應(yīng)用jmeter.bat灶壶,選擇菜單“運行”--->“遠程啟動”肝断,來分別啟動agent?,也可以直接選擇“遠程全部啟動”來將所有的agent啟動驰凛。
遇到的常見問題:
1胸懈、在Controller端上控制某臺機器Run,提示"Bad call to remote host"洒嗤。
解決方法:檢查被控制機器上的jmeter-server有沒有啟動箫荡,或者JMeter.properties中remote_hosts的配置錯誤。
2渔隶、Agent機器啟動Jmeter_server.bat時羔挡,后臺提示:"could not find ApacheJmeter_core.jar"
解決方法:確定在Agent機器安裝jdk,并設(shè)置環(huán)境變量
3间唉、遠程啟動時绞灼,報錯:
ERROR - jmeter.gui.action.RemoteStart: Failed to initialise remote engine java.rmi.ConnectException: Connection refused to host: 127.0.0.1; nested exception is:
java.NET.ConnectException: Connection refused: connect
at sun.rmi.transport.tcp.TCPEndpoint.newSocket(Unknown Source)
at sun.rmi.transport.tcp.TCPChannel.createConnection(Unknown Source)
at sun.rmi.transport.tcp.TCPChannel.newConnection(Unknown Source)
at sun.rmi.server.UnicastRef.newCall(Unknown Source)
at sun.rmi.registry.RegistryImpl_Stub.lookup(Unknown Source)
at java.rmi.Naming.lookup(Unknown Source)
at org.apache.jmeter.engine.ClientJMeterEngine.getEngine(ClientJMeterEngine.java:54)
at org.apache.jmeter.engine.ClientJMeterEngine.(ClientJMeterEngine.java:67)
at org.apache.jmeter.gui.action.RemoteStart.doRemoteInit(RemoteStart.java:180)
at org.apache.jmeter.gui.action.RemoteStart.doAction(RemoteStart.java:80)
at org.apache.jmeter.gui.action.ActionRouter.performAction(ActionRouter.java:81)
這個問題終于被我解決了,其實原因好簡單呀呈野。只要將本機的jmter-server.bat執(zhí)行即可低矮。要是在jmeter.properties配置的地方寫了127.0.0.1 的話 就要開本機的 jmeter-sever.bat. 不寫的話 就不用開了
4、查看1099端口是否被占用
netstat -ano | findstr "1099"
tasklist | findstr "1099"