查看原文
其他

优秀的测试工程师为什么要懂大型网站的架构设计

茹炳晟 茹炳晟聊软件研发 2022-11-12
如果你是工作在传统软件企业的工程师的话,网站的架构设计知识对你来说可能没那么重要。因为,你的测试对象是传统软件,此时你需要对你的被测软件的架构有比较深入的理解。
而现在如你所知,互联网企业已经占据软件产品的大半壁江山。如果你想跳出传统软件产品测试这个舒适区的话,那互联网企业将是一个最可能的去向。
而在互联网企业进行软件测试的话,很多时候需要针对互联网的架构来设计有针对性的测试,另外对于互联网的压力测试以及结果分析也需要对架构知识有比较清楚的认识。这时,不懂得网站架构设计知识,在开展测试时,就真的会有处处被掣肘的感觉了。更别提,这还会直接影响到你的能力提升和职业发展了。
在测试过程中,你可能会经常遇到诸如负载均衡器、缓存集群、数据库读写分离、消息队列、CDN、反向代理服务器和分布式数据库等概念,在测试执行中也经常会和这些系统打交道。但是你可能并不清楚这些组件真正的作用。
还有些时候,特别是性能测试,如果你不清楚详细的架构设计以及其中的技术细节,你可能根本无去解读和分析性能测试的报告。
我来举两个实际的例子吧。

基于消息队列的分布式系统测试设计的例子

在分布式系统的架构中,为了减少各个应用系统之间的直接耦合,往往会引入消息队列来实现解耦。
也就是说原本的功能实现是由系统A调用系统B来完成业务功能的,而引入了消息队列后,系统A不会再直接去调用系统B,而是将调用B所需要的数据放到了消息队列中,此时我们将系统A称为消息的生产者,然后系统B通过监听该消息队列,主动从消息队列中依次抓取数据进行系统B的处理,系统B在这种情况下称为消息的消费者。通过这种方式,就完成了系统A和系统B之间的调用解耦。
那么,我们再来看测试的设计。测试用例的设计可以站在黑盒测试的视⻆,完全不需要知道消息队列的存在,而直接从业务功能的层面去设计用例。但如果只这么做的话,你会发现虽然你的测试全部通过了,但是产品一旦到了线上,还可能会出现很多问题。
比如说,消息的生产者产生消息的速度远远大于消息消费者处理消息的速度时,很可能会造成消息队列满的情况,此时系统的行为是怎么样的? 显然仅仅通过黑盒测试很难完成系统性的、全面的测试。要做到系统性全面的测试设计,你就必须知道消息队列的基本原理,然后在此基础上去设计针对具体架构的测试用例和场景。
另外,既然我们的系统设计希望是解耦的,那么我们的测试设计也希望是解耦的。也就是说, 对于一些更详细的测试,我们希望系统A和系统B可以被单独的进行测试。那么,这个时候,如果是对系统A进行测试的话,你的测试验证就需要在消息队列中进行。同样的道理,如果你是对系统B进行测试的话,你就需要在消息队列中构造测试输入数据了。
由此可⻅,如果你不知道消息队列的存在以及其基本原理的话,你的测试将寸步难行。

缓存的例子

很多时候,在我们搭建完性能测试的基准环境,开始执行性能基准测试的时候,往往会发现系统刚开始运行时业务处理的响应时间都会相对比较⻓,只有当性能测试执行了一段时间后,系统的各项指标以及事务的响应时间才逐渐趋于正常。
为此,在做性能基准测试的时候,有经验的工程师通常都会先用性能场景对系统进行一下“预热”,然后再真正开始测试。你有想过这其中的原因吗?
另外,在做前端性能测试的时候,我们对于一个⻚面的打开时间通常会去统计两个指标,一个是首次打开时间,另一个是多次打开的时间。而且,通常来讲首次打开时间会远大于后面再次打开的时间。你有想过这其中的原因吗?
其实,造成上述两种情况的背后原因都是采用了缓存技术。
造成第一个情况的原因,是服务器端会对“热点”数据进行缓存,而不是每次访问都直接从数据库中获取数据。那么,系统刚开始运行时,由于没有任何之前的访问记录,所有数据都需要访问数据库,所以前期的事务响应时间都会比较⻓。但是,随着缓存的建立,后续的访问就会比较快了。这个前期对系统的“预热”过程其实是在“预热”缓存。
对于第二种情况也是同样的道理。浏览器端也会缓存从服务器端拿到各种静态资源,在第一次访问时这些资源都需要从服务器端获取,而后面再访问时,这些静态资源已经在浏览器的缓存中了,所以访问速度会大大加快。
由此可⻅,如果不知道缓存的存在、不理解缓存的基本原理,你就不可能从根本上理解性能测试的方法设计以及测试结果数据。
其实,对于缓存还有很多需要考虑的测试点,但是需要解释这些测试点就需要深入理解缓存的原理以及缓存的架构设计,因为在互联网环境下,缓存本身也是分层的,浏览器端有本地缓存、网络端有CDN缓存、数据中心前端有反向代理的缓存、应用服务器端有本地缓存,对于大规模互联网应用更有大规模的专用缓存服务器集群。所以,要有针对性的设计缓存相关的测试场景,就需要理解这些缓存的架构。
那么,接下来我就和你聊聊作为测试工程师应该怎么学习架构知识。

架构知识的学习方法

其实,对于测试工程师来说,学习软件架构和系统架构知识的确是个不小的挑战。因为很多架构知识都是基于开发框架和系统设计的,对开发工程师来说,已经是个不小的挑战,对测试工程师来说更是一个难以驾驭的领域。
不过好在,同样是对架构知识的学习和掌握,不同⻆色的工程技术人员都有不同的视⻆,需要了解和掌握的全局知识和细节程度也各不相同。以消息队列知识为例:
  • 如果你是系统架构师,那么你就不仅要掌握各个不同消息队列实现的技术细节,还清楚不同方案的优势和劣势,最关键的是能够根据业务的应用场景和特点来选择最合适的消息队列方案。
  • 如果你是软件开发人员,那么你就需要掌握消息队列的使用方法、消息push和pull的模式,以及在应用中如何以异步方式来对消息进行妥善处理,并且还要考虑到异常场景的处理。
  • 而作为软件测试人员,你需要知道消息队列的基本原理以及在被测系统中的部署情况,同时应该知道如何访问消息队列或者队列中消息的情况。在需要模拟消息进行解耦测试的场合,你还需要知道如何添加测试消息以满足测试的目的。
可⻅,对于测试人员来讲,学习架构知识应该有自己独特的视⻆,基本只要做到清楚原理、了解在被测系统中的部署架构,从测试的⻆度能够调用必要的接口就可以了。
那么,我们到底应该怎么来学习架构知识呢?根据我的个人经验,我认为应该遵循“由广度到深度”和“自上而下”两个基本原则。
  • “由广度到深度”中的“广度”是指在平时工作以外的时间中,应该多注重全领域架构知识的积累,此时那些系统性地介绍架构知识的书籍就可以给你最大程度的帮助了。因为这类资料往往已经对纷繁复杂的架构知识做了系统性地梳理,它们都能帮你从广度上积累架构知识。
  • “由广度到深度”的“深度”是指,对于架构中某一领域的特定知识在项目中要实际使用的时候,必须要刨根问底,通过实际的测试来加深对架构知识细节的理解。
  • “自上而下”是指,在实际测试项目中,当需要设计涉及架构的测试用例和场景的时候,千万不要直接基于“点”来设计测试,而是应该:首先通过全局阅读理解上层架构设计。然后,在理解了架构设计的初衷和希望达成目的的基础上,再向下设计测试场景和用例。
这个过程,一方面可以帮你设计出有针对性的测试用例,另一方面可以帮助你理解架构在实际项目中是如何落地的。
随着你经历的项目越来越多,你的架构知识就会逐渐充实丰满起来。这就好比你在走一个旋转楼梯,一直感觉自己在原地打转,但是不知不觉走了一段时间后你回头往下看的时候,就会发现已经站在了比原来更高的点上。
最后,我再特别提一下,对于架构知识的学习没有任何捷径可走,你必须一步一个脚印,才能达到下一个高峰,在学习的道路上,你走的每一步都算数。

推荐阅读
一个即将秃头的工程师,解答你对“变异测试”的所有困惑
深入浅出谈软件的“可测试性”
浅谈软件研发的复杂性与应对之道
如何用研发效能搞垮一个团队
如何搞垮一个测试团队?
从研发效能的视角谈“故障复盘”
一文读懂:微服务下的API测试
混沌工程杂谈

推荐书籍
《测试工程师全栈技术进阶与实践》
13次印刷,电子版超过5W+订阅。

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存