评论

收藏

[Java] 浅谈JMeter engine启动原理

编程语言 编程语言 发布于:2021-12-25 19:09 | 阅读数:381 | 评论:0

本文主要介绍jmeter在控制台在点击执行之后底层所做的一些主要事情及内容,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
一、简介
本文主要介绍jmeter在控制台在点击执行之后底层所做的一些主要事情及内容,由于便于断点调试采用GUI方式进行操作

二、配置简介
为了调试方便,采用单线程,方式访问百度(若多线程可能断点会看晕,后面会讲到)
DSC0000.jpg

DSC0001.jpg


三、开始原理讲解
首先GUI下点击执行,在ActionRouter该类下执行performAction()方法,该类为执行后续流程的入口
ActionRouter是一个监听器,用于监听GUI事件流变化进行相应的操作
DSC0002.jpg

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

DSC0004.jpg

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

run()方法做了些什么
从这两张图我们明白,jmeter启动过程会优先运行setup线程组中配置,其次运行线程组中配置,最后运行teardown线程组中配置
DSC0006.jpg

DSC0007.jpg

DSC0008.jpg

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

DSC00010.jpg

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

DSC00012.jpg

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

DSC00014.jpg

DSC00015.jpg

DSC00016.jpg

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

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

DSC00019.jpg

通过impl.sample(u, method, areFollowingRedirect, depth)函数会进入到HTTPHC4Impl实现类的sample方法,找到httpResponse = executeRequest(httpClient, httpRequest, localContext, url)执行部分
这个executeRequest()方法中会发生httpclient请求获取到响应数据
DSC00020.jpg

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

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

processSampler()函数执行完之后会到sam = threadGroupLoopController.next();代码块
该代码块会得到一个LoopController循环控制器,获取下一个取样器Sampler,若没有则会跳出while循环
最后做一些清理动作
DSC00023.jpg

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


四、JMeter 引擎启动链路图
DSC00025.jpg

到此这篇关于浅谈JMeter engine启动原理的文章就介绍到这了,更多相关JMeter engine启动内容请搜索CodeAE代码之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持CodeAE代码之家!
原文链接:https://blog.csdn.net/weixin_40686603/article/details/113700412

关注下面的标签,发现更多相似文章