博客
关于我
重学TCP协议(7) Timestamps 选项
阅读量:774 次
发布时间:2019-03-24

本文共 1043 字,大约阅读时间需要 3 分钟。

Timestamps选项:TCP错误提示的深度解析

1. Timestamps选项的组成

Timestamps选项是TCP协议中用来处理超时和错误提示的一种机制。它由四个字节组成,具体结构为:

  • Kind字段(1字节):确定字段类型,固定为8(表示Timestamp)。
  • Length字段(1字节):存储字段长度,固定为10。
  • Info字段(8字节):包含两个4字节的值,分别为timestamptimestamp echo,用于存储发送和确认的时间戳信息。

这种设计允许客户端和服务器同时获取和验证对方的时间戳,从而在必要时发送错误提示。

2. Timestamps选项的工作原理

假设设备A发送数据时,将当前时间1590508660记录到发送时间戳(TSval),设备B在接收数据后,将接收的时间戳1590508660复制回发送方(TSecr),同时将自己的当前时间1499872733记录到发送时间戳(TSval),并通过ACK确认通知设备A。设备A在收到确认时,可以计算RTT(往返时间)=当前时间戳 - 发送时间戳。

这种机制不依赖于时钟同步,也无需处理时区差异,因为时间戳是单调递增的。


3. Timestamps选项的作用

3.1.RTT计算

Timestamps选项的主要功能是计算网络的往返时间(RTT)。设备在发送数据时记录当前时间戳,在接收确认时,复制该时间戳到响应报文中。设备在收到确认后,可以通过当前时间戳减去发送时间戳,准确计算RTT,从而评估网络性能。

3.2.PAWS:防止回绕序号

在高速网络中,序列号可能每天重复使用,导致混乱。Timestamps选项通过记录实际发送时间,帮助识别重复序列号,保证序号的唯一性,避免PAWS(等待回绕序号空间)等问题。


4. Timestamps选项与三次握手的关系

在三次握手过程中,服务器误用Timestamps选项可能导致客户端发送RST(重传请求停止)。例如,如果服务器回复的TSecr不等于客户端发送的TSval,客户端会识别异常,并发送RST终止连接。


5. Timestamps选项的注意事项

  • 双向启用:需客户端和服务器同时开启,才能有效防止误报错误。
  • 溢出风险:时间戳可能因溢出导致异常,需关注系统时钟的稳定性。
  • 时间步调同步:网络节点的时间增长可能不同步,需确保节点时钟同步。

通过以上机制,Timestamps选项在TCP协议中发挥了关键作用,不仅保障了数据传输的准确性,还优化了网络的拥塞控制。

转载地址:http://nfekk.baihongyu.com/

你可能感兴趣的文章
MYSQL查询语句优化
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加外网访问权限
查看>>
mysql添加用户
查看>>
MySQL添加用户、删除用户与授权
查看>>
mysql添加用户及权限
查看>>
Mysql添加用户并授予只能查询权限
查看>>
mysql添加用户权限报1064 - You have an error in your SQL syntax问题解决
查看>>
mysql添加索引
查看>>
mysql添加表注释、字段注释、查看与修改注释
查看>>