性能测试分层模型-选自书籍:小强软件测试疯狂讲义

百度搜索:小强测试品牌

新书推荐

本书终于在前段时间出版了,现在已经可以在各大网店购买了,搜索书名即可。书籍购买地址:https://detail.tmall.com/item.htm?id=547310727717

这里我特别提前说一句:任何东西都有一定的受众群体,世界上也没有任何东西可以让所有人100%满意。So,本书也是。只要本书中有一个篇章的内容给你带来了影响那就是这本书的价值!感谢大家的支持。

引子

我为什么会把这个话题放到最开始呢?就是因为这些年在企业工作中、在教育领域培训中接触过不少朋友,在这个过程中我发现居然有95%以上的朋友不明白什么是性能测试,什么是自动化测试,这都不要紧,但更可怕的是还对这些概念有巨大的误解,从而导致学习的时候走了很多弯路,看的我也是万般无奈,所以我们就先来好好聊聊性能测试和自动化测试到底是什么,希望能帮助大家更加全面、深刻的理解它们。千万不要小瞧这些,如果你的认知都是错的,你怎么可能学的对呢?

另外,我也必须在开篇中指出一点:所有人的学习都需要一个过程,也许你身边有同事已经经历了A阶段到达了B阶段,他或许会从技术层面鄙视你或者批判你,但是你不要气馁,谁都不是从娘胎里出来就会说话、就会跑步的,都需要经历这个特别“低级”的阶段,这是必然。我们会一直坚持正能量带领“新人”成长,帮助你完成阶段性的蜕变。

性能测试到底是什么

这个看似简单的问题我相信很多朋友都无法全面地回答上来。可能知道的朋友会说性能测试就是用LoadRunner或者Jmeter工具搞个并发来压测系统,也可能会说性能测试就是同时让很多人访问系统看系统能否扛得住。这些回答我只能说对,但不够全面,也不够深刻,只是把表象描述了一下而已。其实真正的性能测试无法用一两句话来简单概括,因为它涉及的东西太多了。

大部分小白朋友一说性能测试理解的就是压测服务器,看服务器能不能扛得住,但这只是其中一方面而已,其实性能测试可以分为多个层级,每个层级的关注点以及测试方法等都不太一样,我们常认为的是服务器端侧的性能测试。至于性能测试的分层我们会在后面的章节中给大家讲解。

那性能测试到底应该怎么去理解呢?我们不妨换个角度来看看,不论是大家理解的通过工具来压测系统还是号召100个人同时去访问系统,都不过是实现的手段或者方法而已,我们更应该关注性能测试的目的是什么,因为目的不一样那么实现的手段或者方法就有可能不一样。所以我们倒着来看看性能测试,不外乎就是这么几个目的:

1) 压测系统看系统的前端以及后端是否满足预期(类似功能测试用例中的预期结果和实际结果的概念);

2) 压测系统看系统可以承受的最佳压力和最大压力,来判断系统的承受极限;

3) 压测系统看系统在长时间运行下是否可以正常处理请求(类似疲劳测试)

4) 容量规划,当系统越来越稳定的时候,我们要提前考虑它的远景规划,或者更通俗的解释就是“人无远虑,必有近忧”,这里的“远虑”就是容量规划。

这样看来我们应该就能明白性能测试其实更多的是一个过程的统称,并不是一个具体的定义,同时在学习性能测试的时候要暂时抛开功能测试的思想,否则很容易掉进陷阱,这也是大部分小白朋友最容易犯的错误。

性能测试分层模型

性能测试分层模型是为了让大家更容易理解和学习性能测试而总结出来的,即使对于有一些经验的朋友,我觉得这个分层模型也会对你在认知上有所帮助的。该分层模型并不高大上,也有可能不够完善,只是对杂乱的知识做了总结提炼,但对于小白朋友来说是非常好的良药,可以帮助大家快速、全面地理解性能测试。分层模型如图1.1所示。

下面我们就来看看这个性能测试分层模型中每层所代表的含义。

前端层

前端层主要是指用户看到的页面。比如,电商网站的首页、移动APP的各个页面,这些是用户最关心的。对于用户而言,你一个系统的快慢他们只会通过页面的展现速度来判断,并不会在意你后端处理的速度,所以我经常说即使你后端优化得很牛逼,但前端页面性能却非常差,那也是无用功。

以前这个层级是很多企业和测试工程师并不关注的,但近几年对于前端性能的要求也越来越高,也是大家应该了解的知识。本书将在后面的章节中详细讲解前端性能方面的知识和实践经验。

另外,APP的测试也是大家经常问到的问题,我有时候特别无奈,大家张口就问:“APP性能测试怎么做啊?”,这样的问题真的没法回答。APP的性能测试至少包括两个方面:APP的前端,也是现在业界里常说的APP专项测试;APP的后端,本质上和Web

侧性能测试一样。所以,在问之前一定要明白这些知识别人才能有针对地回答你。

网络层

任何系统都可以粗略地分成客户端、网络和服务器端,其中网络是连接前后端的命脉,网络质量的好坏也有很大的影响。在性能测试中可能遇到的情况大致分为两种,一种是测试不同网络状况下的大流量的表现(一般接触的比较少),另一种则是压力机和服务器最好在同一网段,不然压力无法完整的到达后端,会在网络层拖垮,这样就没法较为准确地评测服务器端的性能情况了。如果你测试的是移动端APP,那么你可能还要考虑在不同网络状态下的测试。对于网络层的性能测试我接触的非常少,为了不误人子弟这里就不班门弄斧了。大家的重点是了解这个分层模型,对于理解性能测试很重要。

后端层

这里我分成了三种情况,也是绝大多数企业中应用的方向,是大家必须了解和掌握的。同时大家也要明白,不论是Web端还是移动APP端,在后端层性能测试的方法都是类似的。

第一,业务级:通俗点解释就是从页面录制你的场景脚本。比如,现在有一个小强电商网站,你要通过页面录制脚本完成登录、浏览单品页、下单的流程。这个层级我想大家是最熟悉的,因为LoadRunner这个工具就是用来完成这样的流程的,也是大部分小白同学必学的。至于怎么去完成我们在后面的章节中会详细讲解到。

这种性能测试方式有个致命的缺点就是依赖于页面,如果页面没有开发完毕测试就无法提前进行,而现实中测试时间往往被一味压缩,因此我们有时候也很无奈,所以如何把测试的切入点尽可能的提前就显得比较重要了。而接口级恰恰就解决了这个问题。

第二,接口级:这个层级是大部分公司做性能测试的首选,也是最有效率的方式之一。比如,现在有一个登录接口,你只需要知道入参、出参以及规则等即可编写测试接口的代码,不需要等待页面的开发,大大提前了测试的切入点,但它要求测试工程师有一定的编码能力。除此之外,接口级测试的扩展性强,可以通过完成接口的性能测试和功能自动化测试框架来提升效率,性价比较高。具体如何去完成将在后面的章节中详细讲解。

第三,单元级:这个层级恰恰和接口级相反,很多公司想做,但有心无力。单元级大家理解为类似“单元测试”即可,比如,有一个PHP代码块,我们可能需要测试一下核心算法函数的性能,可以通过插桩或引入单元测试框架来完成,从而获得它的执行时间、CPU消耗以及内存占用率等信息来优化代码性能,如图1.2所示。

那为什么很多公司做不起来单元级的测试呢?可能有几个原因:

1) 业务变化太快,涉及的代码逻辑修改也比较大,这样做单元级测试就得不偿失了。

2) 开发朋友们确实没有太多的时间写单元测试代码,毕竟业务逻辑代码写起来也很费时,没有太多时间搞其他了。

3) 测试工程师编码能力相对来说较弱,能独当一面完成单元测试的人少之又少,在加上时间紧迫就更无法做单元级的测试了。

我们聊完这些分层后,也许有的朋友会感觉其中有些技术很厉害,感觉很高大上。可是我个人觉得不是你用多么厉害的技术就牛逼,只有用合适的技术带来较高的性价比才是王道,有句话说的好:“最好的不一定是合适的,只有合适的才能发挥最好的效果”。

看完这些不知道大家是不是对性能测试有了不一样的了解。当然,这个模型不见得是最好的,只是根据经验总结而来,也有很大的改进空间,我希望的是能和大家一起交流来完善,并不希望来争论对与错,世间本身没有绝对的对与错,只有更多的交流你才能吸收更多的知识来武装提升自己,俗话说的好:“你一个想法,我一个想法,我们交流一下就彼此拥有了两个想法”,何乐而不为呢。

转载需注明出处!

时间: 2024-10-25 21:49:44

性能测试分层模型-选自书籍:小强软件测试疯狂讲义的相关文章

《小强软件测试疯狂讲义-性能及自动化》一书正式发布

本书即日起将在各大网上书店陆续发布,欢迎大家选购!可在china-pub.com,京东,当当,天猫等网店购买,搜索"小强软件测试疯狂讲义"关键字即可查找并购买了哦!   出版社官方天猫购买地址(推荐):https://detail.tmall.com/item.htm?id=547310727717 当当购买地址:http://product.dangdang.com/24239858.html 京东购买地址:https://item.jd.com/12161074.html chin

小强软件测试疯狂讲义-性能及自动化

乌拉拉~4月1日左右应该就可以在各大网上书店购买到了哦,小伙伴在等等,现在放出高清无码照~ 购买地址:暂时没有...有了我就放出来

数据封装 DataEncapsul时网络分层模型

如今学习分了十分十分重 要.重要性重要到网络课程学(图1数据封装)习中不论怎么也得也得把握它首要 内容是一个包.悉数数据包含 TFTP头被别的一个协议 这儿是UDP封装,先是被榜首个协议这儿是TFTP报头(或许 报尾)包装封装"然后.然后下一个IP一贯重复下去,直到硬件物理层这儿是以太网 当别的一台机器接纳到包.内核剥去IP和UDP头,硬件先剥去以太网头.TFTP次序再剥去TFTP头,毕竟得到数据.如今总算讲到身败名裂的网络分层模型 LayerNetworkModel这种网络模型在描绘网络体系上

小强软件测试&挨踢脱口秀微信群成立,加入坐等福利哦

小强测试&挨踢脱口秀微信群成立了!欢迎大家加入,纯属自愿!微信群以后主要是用于如下几个地方: 1.重要事情的通知(至于什么东东暂时保密哦,待年底揭晓.随便说一下,本群里基本无广告,偏绿色哦) 2.分享.交流 3.平时基本不会骚扰大家,喜欢安静的人可以加入 加入方法: 请先加木子的微信(qiangfans)或扫下方二维码,备注:入群. 之后木子会统一拉大家入群哦. 小强软件测试&挨踢脱口秀微信群成立,加入坐等福利哦

Internet概念与TCP/ IP分层模型

Internet是世界上规模最大.用户最多.影响最大的计算机互联网络.本模块介绍Internet的概念及TCP/ IP分层模型. 一.Internet的概念 Internet的概念(也可认为是Internet的结构)可以从以下几个方面理解: 从网络通信的观点来看,Internet是一个由TCP/IP把各个国家.机构.部门的内部网络连接起来的庞大的数据通信网: 从信息资源的角度来看,Internet是一个集各个领域.部门内各种信息资源,以共享为目的的信息资源网: 从技术的角度来看,Internet

理解 Neutron Server 分层模型 - 每天5分钟玩转 OpenStack(69)

本节开始讨论 Neutron 的各个服务组件,首先学习 Neutron Server . 上图是 Neutron Server 的分层结构,至上而下依次为: Core API对外提供管理 network, subnet 和 port 的 RESTful API. Extension API对外提供管理 router, load balance, firewall 等资源 的 RESTful API. Commnon Service认证和校验 API 请求. Neutron CoreNeutron

网络分层模型

目前存在的两种网络分层模型:OSI模型和TCP/IP模型.OSI模型一共分为七层,TCP/IP模型和OSI模型类似,但是只分为四层. OSI模型 OSI的全程是Open Systems Interconncection,即开放系统互联,它由ISO(International Organization for Standardization)制定.OSI是网络通信的一种通用框架,它分为七层,并且定义了在每一层上数据的处理方法. 层数 层名 备注 7 应用层(Application) 6 表示层(P

( 转)性能测试--地铁模型分析

( 转)性能测试--地铁模型分析 地铁模型分析 和绝大部分人一样,小白每天都要乘坐地铁上下班,那么就拿地铁来分析,再次深刻理解下性能.早上乘坐地铁上班,最典型的就是北京地铁1.5.10.13号线等,人多得简直没法形容!为了方便理解分析,先做如下假设. 某地铁站进站只有3个刷卡机. 人少的情况下,每位乘客很快就可以刷卡进站,假设进站需要1s. 乘客耐心有限,如果等待超过30min,就会暴躁.唠叨,甚至选择放弃. 按照上述的假设,最初会出现如下的场景. 场景一:只有1名乘客进站时,这名乘客可以在1s

性能测试负载模型(五)

我们上一篇文章说到了性能测试负载模型落地时的建模方法,这里我们先就第一种也是最常用的一种方法说起: 原始数据分析法 业务场景建模主要就是说明用户如何使用系统,因此根据系统使用的原始数据也就是日志进行分析建模是最有效最准确的方法.所谓日志就是指用户操作系统的痕迹,根据记录信息时的不同视角,一般分为两类:一类视角是基于用户,我们称之为操作日志,这类日志主要以用户为观察实体,记录用户从登录系统到离开系统的每一个动作:另一类视角基于系统,我们称之为访问日志,这类日志主要为应用系统为观察实体,记录系统的输