浅谈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启动内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

以上是 浅谈JMeter engine启动原理 的全部内容, 来源链接: utcz.com/p/248583.html

回到顶部