温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JMeter中engine启动的示例分析

发布时间:2021-09-05 10:34:42 来源:亿速云 阅读:164 作者:小新 栏目:开发技术

这篇文章主要介绍了JMeter中engine启动的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

一、简介

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

二、配置简介

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

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

三、开始原理讲解

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

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

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

run()方法做了些什么

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

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

JMeter中engine启动的示例分析

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

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

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

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

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

最后做一些清理动作

JMeter中engine启动的示例分析

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

JMeter中engine启动的示例分析

四、JMeter 引擎启动链路图

JMeter中engine启动的示例分析

感谢你能够认真阅读完这篇文章,希望小编分享的“JMeter中engine启动的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI