淺談JMeter engine啟動原理

一、簡介

本文主要介紹jmeter在控制臺在點擊執行之後底層所做的一些主要事情及內容,由於便於斷點調試采用GUI方式進行操作

二、配置簡介

為瞭調試方便,采用單線程,方式訪問百度(若多線程可能斷點會看暈,後面會講到)

在這裡插入圖片描述

在這裡插入圖片描述

三、開始原理講解

首先GUI下點擊執行,在ActionRouter該類下執行performAction()方法,該類為執行後續流程的入口

ActionRouter是一個監聽器,用於監聽GUI事件流變化進行相應的操作

image-20210205141450948.jpg

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啟動內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: