浅谈JMeter engine启动原理

一、简介

本文主要介绍jmeter在控制台在点击执行之后底层所做的一些主要事情及内容,由于便于断点调试采用GUI方式进行操作

二、配置简介

为了调试方便,采用单线程,方式访问百度(若多线程可能断点会看晕,后面会讲到)

浅谈JMeter engine启动原理_第1张图片

浅谈JMeter engine启动原理_第2张图片

三、开始原理讲解

首先GUI下点击执行,在ActionRouter该类下执行performAction()方法,该类为执行后续流程的入口

ActionRouter是一个监听器,用于监听GUI事件流变化进行相应的操作

浅谈JMeter engine启动原理_第3张图片

2. 进入Start类中doAction方法,会调用startEngine函数,表示开启jmeter引擎,当然不是里面开启,会在该函数进行一系列前置处理

浅谈JMeter engine启动原理_第4张图片

浅谈JMeter engine启动原理_第5张图片

接下来进入到StandardJMeterEngine类,这才是真正启动jmeter engine的入口,接下来我们看看在runTest函数中都做了些什么

浅谈JMeter engine启动原理_第6张图片

run()方法做了些什么

从这两张图我们明白,jmeter启动过程会优先运行setup线程组中配置,其次运行线程组中配置,最后运行teardown线程组中配置

浅谈JMeter engine启动原理_第7张图片

浅谈JMeter engine启动原理_第8张图片

浅谈JMeter engine启动原理_第9张图片

接下来讲解线程组到底如何运行,上图while (running && iter.hasNext()) {}代码块部分

浅谈JMeter engine启动原理_第10张图片

浅谈JMeter engine启动原理_第11张图片

现在我们进入到ThreadGroup该类处理环节,看看它到底做了什么

浅谈JMeter engine启动原理_第12张图片

浅谈JMeter engine启动原理_第13张图片

newThread.start()后我们开始进入JMeterThread类中run方法,看看它做了些什么,开始越来越接近重点了

浅谈JMeter engine启动原理_第14张图片

浅谈JMeter engine启动原理_第15张图片

浅谈JMeter engine启动原理_第16张图片

浅谈JMeter engine启动原理_第17张图片

doSampling()函数中会执行sampler.sample(null)该段代码,这里面会执行sample()方法并接收返回结果

浅谈JMeter engine启动原理_第18张图片

上图打进去后会进入HTTPSampleProxy类调用sample函数,通过HTTPSamplerFactory工厂方法来获取请求类别

浅谈JMeter engine启动原理_第19张图片

浅谈JMeter engine启动原理_第20张图片

通过impl.sample(u, method, areFollowingRedirect, depth)函数会进入到HTTPHC4Impl实现类的sample方法,找到httpResponse = executeRequest(httpClient, httpRequest, localContext, url)执行部分

这个executeRequest()方法中会发生httpclient请求获取到响应数据

浅谈JMeter engine启动原理_第21张图片

然后将响应数据以及请求配置的一些参数数据都传入到HTTPSampleResult类对象中,而HTTPSampleResult的父类就是SampleResult,到这儿请求响应处理结束

浅谈JMeter engine启动原理_第22张图片

doSampling()函数处理完之后,就是得到的HTTPSampleResult对象做一些处理

浅谈JMeter engine启动原理_第23张图片

processSampler()函数执行完之后会到sam = threadGroupLoopController.next();代码块

该代码块会得到一个LoopController循环控制器,获取下一个取样器Sampler,若没有则会跳出while循环

最后做一些清理动作

浅谈JMeter engine启动原理_第24张图片

StandardJMeterEngine类run方法结尾部分,至此整个jmeter引擎启动到结束就到此结尾了

浅谈JMeter engine启动原理_第25张图片

四、JMeter 引擎启动链路图

浅谈JMeter engine启动原理_第26张图片

到此这篇关于浅谈JMeter engine启动原理的文章就介绍到这了,更多相关JMeter engine启动内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的