jmeter壓力測試實現(xiàn)負載均衡

文章來源于:https://blog.csdn.net/russ44/article/details/54729461

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"

其它說明:

  1、調(diào)度機(master)和執(zhí)行機(slave)最好分開叔汁,由于master需要發(fā)送信息給slave并且會接收slave回傳回來的測試數(shù)據(jù)统求,所以mater自身會有消耗,所以建議單獨用一臺機器作為mater据块。

  2码邻、參數(shù)文件:如果使用csv進行參數(shù)化,那么需要把參數(shù)文件在每臺slave上拷一份且路徑需要設(shè)置成一樣的另假。

  3像屋、每臺機器上安裝的Jmeter版本和插件最好都一致,否則會出一些意外的問題边篮。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末己莺,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子戈轿,更是在濱河造成了極大的恐慌凌受,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件思杯,死亡現(xiàn)場離奇詭異胜蛉,居然都是意外死亡,警方通過查閱死者的電腦和手機色乾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進店門誊册,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人暖璧,你說我怎么就攤上這事案怯。” “怎么了漆撞?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵殴泰,是天一觀的道長。 經(jīng)常有香客問我浮驳,道長悍汛,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任至会,我火速辦了婚禮离咐,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘奉件。我一直安慰自己宵蛀,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布县貌。 她就那樣靜靜地躺著术陶,像睡著了一般。 火紅的嫁衣襯著肌膚如雪煤痕。 梳的紋絲不亂的頭發(fā)上梧宫,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天,我揣著相機與錄音摆碉,去河邊找鬼塘匣。 笑死,一個胖子當(dāng)著我的面吹牛巷帝,可吹牛的內(nèi)容都是我干的忌卤。 我是一名探鬼主播,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼楞泼,長吁一口氣:“原來是場噩夢啊……” “哼驰徊!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起堕阔,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤辣垒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后印蔬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體勋桶,經(jīng)...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年侥猬,在試婚紗的時候發(fā)現(xiàn)自己被綠了例驹。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡退唠,死狀恐怖鹃锈,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情瞧预,我是刑警寧澤屎债,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布仅政,位于F島的核電站,受9級特大地震影響盆驹,放射性物質(zhì)發(fā)生泄漏圆丹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一躯喇、第九天 我趴在偏房一處隱蔽的房頂上張望辫封。 院中可真熱鬧,春花似錦廉丽、人聲如沸倦微。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽欣福。三九已至,卻和暖如春焦履,著一層夾襖步出監(jiān)牢的瞬間劣欢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工裁良, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留凿将,地道東北人。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓价脾,卻偏偏與公主長得像牧抵,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子侨把,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,435評論 2 359