协议的学习技巧

简介: 协议的学习技巧

640.jpg

不论是做接口测试还是性能测试,本质上都是在和协议打交道。除了最常见的Http协议外,当遇到其它的通信协议时,我们要如何快速学习它,以便能够更好地测试它呢?


01


什么是通信协议呢?通信协议为计算机网络中进行数据交换而建立的规则、标准或约定的集合。简单而言,就是机器之间的“语言”。区别于编程语言(JAVA、C等,那是人机之间的语言)。如图1-1所示,在不同的系统层级中,存在着各类不同的通信协议。


640.png

1-1不同系统层级中的协议分布


协议是由三个要素组成:   语义:表示要做什么; 语法:表示要怎么做;时序:表示做的顺序。所以,我们在学习协议时,只要弄清楚这三个信息,就可以快速掌握并使用它。我们需要关注:1.通讯协议的基本原理 ;2.了解协议的特点及应用场景;3.学会如何发起一个对应请求并接收数据。


02


注意观察下图1-1,细心的你可能会发现,为什么没有我们常见的Socket协议?


Socket是对TCP/IP协议的封装,它本身并不是协议,而是一个调用接口(API)。TCP/IP是一个协议栈,就像操作系统的运行机制一样,必须要具体实现,同时还要提供对外的操作接口,提供给程序员做网络开发所用的接口,这就是Socket编程接口。Socekt协议位于应用层和传输层之间。它有个说法叫“万能协议”,有些系统在应用层使用的是混合协议时,可以统一转换成Socket来处理。


03


小陈同学遇到了一个场景,系统接口是通过tcp长链接来实现的,现在需要针对这个接口进行性能压测,那么他将如何开展工作呢?


首先,要了解下tcp长链接是什么东西(可以通过检索资料、和开发沟通、和组内其他成员沟通来获取这方面的信息,先知道是什么),正常情况下,tcp链接在数据传输完成后,就会主动释放,而在某些场景下,我们需要保持这个链接,这样做的好处是减少连接建立过程的耗时,同时,基于长链接,两端可以很方便地Push数据,做交互,典型的场景就是聊天窗口。而保持长链接的方式通常有两种:系统层的KeepAlive机制,和应用层的心跳检测。

 

在了解了什么是tcp长链接后,就要想办法把这个东西模拟出来,进一步去理解它的原理,那么有哪些工具可以模拟这类的tcp长链接呢?我们以测试人员最常用的Jmeter工具来说明:在TCP Sampler中,有个Re-use connection,如果选中,连接会一直处于打开状态。了解到这个信息后,小陈就知道如何开展这个测试了(TCP的报文如何获取,就在不本篇展开,具体可以查找Wireshark工具的使用)。640.png



图1-2Jmete中的长链接选项


04


通常情况下,小陈的工作可以正常开展,这个话题也就结束了。但小陈毕竟不是普通的小陈,他有自己的思考。还记得我们前面提到的关于通信协议学习的三个内容吗?我们知道了tcp长链接的原理,也清楚了如何去模拟一个长链接。但是忽略了长链接的特点和应用场景了。经过查阅相关资料,小陈总结了长连接和短链接各自的优缺点:

1、长连接可以省去较多的TCP建立和关闭的操作,减少浪费,节约时间,但是一直连接对于客户端来说比较耗电 2、对于频繁请求资源的客户来说,较适用长连接 3、客户端与服务端之间的连接如果一直不关闭的话,会存在一个问题;4、随着客户端连接越来越多,server早晚有扛不住的时候,这时候server端需要采取一些策略,如关闭一些长时间没有读写事件发生的连接,这样可以避免一些恶意连接导致服务端服务受损;5、一次TCP连接和断开需要7个来回,如果客户端请求频繁,将在TCP的建立和关闭操作上浪费大量时间和带宽


通过总结这些特点,小陈又梳理出了关于这次测试的其他需要关注的测试点:


1. 关注服务器建立长链接的数量,避免过多无用的长链接;

2. 和开发沟通长链接保持的时间和检测机制,避免有用的长链接失效;

3. 它的释放机制是如何保障的(毕竟不能一直长链接)



05


事情好像告一段落了。小陈奇奇怪怪的知识又增加了一些。但小陈又进一步做了思考:Jmeter中Re-use connection是如何实现的呢?它的心跳检测机制是如何实现的?研发使用长链接的场景是否合理?是否是必要的?嗯,其实还是有很多东西可以去探讨的。

 

测试人员的成长,就是在这些一步步的思考中沉淀下来了。遇到一个问题,有的人解决了眼前的问题,有的人思考了问题背后的原因(5Why),有的人会进一步地联想和总结。1年,2年,N年之后,差距就逐步体现了。

 

不要被测试这个角色所限制,你应该有更大的发挥空间。


往期推荐:

用心维护自己的职场标签

微服务的测试策略

微服务间的测试策略

单体微服务的测试策略

你还记得测试策略么

相关文章
|
11天前
|
网络协议 算法 网络性能优化
传输层重点协议(TCP协议)深度解剖
TCP协议是网络通信中不可或缺的一部分。通过三次握手建立连接,四次挥手断开连接,流量控制和拥塞控制保证了数据的可靠传输。理解TCP报文格式及其各字段的功能,有助于深入掌握网络协议的工作原理。本文通过实例分析和思维导图,详细剖析了TCP协议的各个方面,为读者提供了一份全面的技术指南。
43 13
|
21天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
85 1
|
7月前
|
网络协议 算法 程序员
网络原理(4)——TCP协议的特性
网络原理(4)——TCP协议的特性
44 1
|
7月前
|
网络协议 前端开发 Java
网络原理(3)——TCP协议的特性
网络原理(3)——TCP协议的特性
57 0
|
8月前
|
网络协议 程序员 网络性能优化
【网络原理】TCP 协议中比较重要的一些特性(三)
【网络原理】TCP 协议中比较重要的一些特性(三)
57 0
|
8月前
|
网络协议
【网络原理】TCP 协议中比较重要的一些特性(一)
【网络原理】TCP 协议中比较重要的一些特性(一)
66 0
|
8月前
|
缓存 网络协议
【网络原理】TCP 协议中比较重要的一些特性(二)
【网络原理】TCP 协议中比较重要的一些特性(二)
55 0
|
网络协议 网络架构
LinuxUDP协议编程(下)
LinuxUDP协议编程(下)
93 0
|
存储 域名解析 网络协议
LinuxUDP协议编程(上)
LinuxUDP协议编程
106 0