客户端多次RST以及不同场景下的RST报文的差异
2016-01-27 15:32
525 查看
我们首先来看客户端发出的第一个RST报文的解码:
RST与ACK标志位都置一了,并且具有ACK number,非常明显,这个报文在释放TCP连接的同时,完成了对前面已接收报文的确认。
我们再来看看客户端发出的后续RST报文的解码:
我们可以看到,这些后续的RST报文仅Reset位置一,ACK位未置一,在这种情况下,该报文的ACK确认号应该为0,但是我们留意到在这个报文中,其ACK确认号与序列号是一致的。
这是为什么呢?
因为ACK位未置一,ACK确认号也就失去了意义,因此,不论ACK确认号是什么值都不会对接收端产生影响,因此大部分的系统都会将ACK确认号设置为0,之所以在这个报文中出现ACK确认号非0而是与序列号一致的情况,个人认为应该是该主机端系统的处理机制与大部分系统不一样导致的。
另外,我们也看到了wireshark的专家系统在此处给出了提示,由此可见wireshark在传输层的专家系统的强大之处。
为什么前后RST报文会出现这种差异?
原因为第一个RST报文是异常释放TCP连接的,在端系统发送RST报文之前,这个TCP连接尚在端系统的连接表中,因此其ACK位置一并且具有ACK确认号。而客户端后续收到DATA报文,因其连接表中已经没有相关信息与之对应,此时客户端发送的RST报文ACK位无需置一。
也许有朋友会问:服务器端为什么在收到客户端的RST报文后,还继续给客户端发送报文呢?
原因只有一个,那就是TCP成块数据流。服务器端一次性向客户端发送数个数据块,在客户端发出第一个RST报文之后,后续的报文已经在网络中传输了,并陆续达到客户端。
其交互过程大致如下:
相关文章推荐
- 互联网协议入门(一)
- TCP/IP建立连接(三次握手)和关闭连接(四次挥手)
- 理解TCP三次握手--大白话
- Python 一步一步学网络编程
- TCP/IP中那些令人豁然开朗的说明
- android中出现"ADB server didn't ACK"这个问题解决方案
- TCP/IP 读书笔记
- 安卓网络应用总结
- #杂问#wireshark的reassemble tcp含义
- TCP C/S程序示例以及问题
- 【转】以太网的帧
- IEEE802帧和EthernetII帧的封装格式对比
- 关于TCP/IP的一些总结
- linux下socket调用的函数介绍
- 大型系统中socket集中管理及select非阻塞读写
- 解决ADB server didn't ACK方法
- TCP/IP的滑动窗口(转载)
- TCP/IP协议与端口
- C# 获得本机IP 和 电脑名称
- TCP/IP协议 HTTP协议