JMeter engine启动 浅谈JMeter engine启动原理
HenryXiao8080 人气:0一、简介
本文主要介绍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 引擎启动链路图
加载全部内容