一、簡介
本文主要介紹jmeter在控制臺在點擊執行之后底層所做的一些主要事情及內容,由于便于斷點調試采用GUI方式進行操作
二、配置簡介
為了調試方便,采用單線程,方式訪問百度(若多線程可能斷點會看暈,后面會講到)
三、開始原理講解
首先GUI下點擊執行,在ActionRouter
該類下執行performAction()方法,該類為執行后續流程的入口
ActionRouter是一個監聽器,用于監聽GUI事件流變化進行相應的操作
2. 進入Start類中doAction方法,會調用startEngine函數,表示開啟jmeter引擎,當然不是里面開啟,會在該函數進行一系列前置處理
接下來進入到StandardJMeterEngine類,這才是真正啟動jmeter engine的入口,接下來我們看看在runTest函數中都做了些什么
run()方法做了些什么
從這兩張圖我們明白,jmeter啟動過程會優先運行setup線程組中配置,其次運行線程組中配置,最后運行teardown線程組中配置
接下來講解線程組到底如何運行,上圖while (running && iter.hasNext()) {}
代碼塊部分
現在我們進入到ThreadGroup該類處理環節,看看它到底做了什么
newThread.start()后我們開始進入JMeterThread類中run方法,看看它做了些什么,開始越來越接近重點了
doSampling()函數中會執行sampler.sample(null)
該段代碼,這里面會執行sample()方法并接收返回結果
上圖打進去后會進入HTTPSampleProxy類調用sample函數,通過HTTPSamplerFactory工廠方法來獲取請求類別
通過impl.sample(u, method, areFollowingRedirect, depth)
函數會進入到HTTPHC4Impl實現類的sample方法,找到httpResponse = executeRequest(httpClient, httpRequest, localContext, url)
執行部分
這個executeRequest()方法中會發生httpclient請求獲取到響應數據
然后將響應數據以及請求配置的一些參數數據都傳入到HTTPSampleResult類對象中,而HTTPSampleResult的父類就是SampleResult,到這兒請求響應處理結束
doSampling()函數處理完之后,就是得到的HTTPSampleResult對象做一些處理
processSampler()
函數執行完之后會到sam = threadGroupLoopController.next();
代碼塊
該代碼塊會得到一個LoopController循環控制器,獲取下一個取樣器Sampler,若沒有則會跳出while循環
最后做一些清理動作
StandardJMeterEngine類run方法結尾部分,至此整個jmeter引擎啟動到結束就到此結尾了
四、JMeter 引擎啟動鏈路圖
到此這篇關于淺談JMeter engine啟動原理的文章就介紹到這了,更多相關JMeter engine啟動內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/weixin_40686603/article/details/113700412