第17章 TCP:传输控制协议
17.2 TCP服务
TCP可靠性通过以下方式提供:
- 应用数据被分割成TCP认为最合适发送的数据块。TCP传递给IP的信息单位称为报文段或段(segment);
- TCP发送一个段后,启动一个定时器。以实现超时管理及重传策略;
- TCP收到另一端的数据后,将(延时几分之一秒)发送一个确认。
- TCP将保持首部和数据的校验和。目的是检测数据在传输中的任何变化。存在差错,将丢弃和不确认收到此报文;
- IP报文到达可能失序。TCP将对收到的数据进行重新排序,将收到的顺序以正确的顺序交给应用层;
- TCP接收端必须丢掉重复的数据;
- TCP提供流量控制。接收端只允许另一端发送接收端缓冲区锁能容纳的数据。
17.3 TCP首部
TCP数据封装在一个IP数据报中。
由于TCP支持全双工通信,故连接的每一段必须保持每个方向上的传输数据序号。
- 32位序号:标识TCP发送的数据字节流,他表示当前的数据首字节在整个传输过程中的字节序号。32bit无符号数据,溢出后从0开始。
- 32位确认序号:表示确认报文所期望收到的下一个序号。只有ACK为1时,确认序号才生效。
- TCP首部长度最大60字节。
6个标志比特:
- URG:紧急指针有效
- ACK:确认序号有效
- PSH:接收方应该尽快将这个报文交给应用层
- RST:重建连接
- SYN:同步序号用来发起一个连接
- FIN:发送端完成发送任务
TCP的流量控制由窗口大小来提供。窗口值表示接收端期望接收的字节。
校验和覆盖了整个TCP报文段:首部和数据。发端计算和存储,接收端验证。
URG置1时,16位紧急指针才生效。紧急指针时一个正的偏移量,和序号字段中的值相加表示紧急数据最后一个字节的序号。
最常见的可选字段是最长报文大小,又称MSS(Maximum Segment Size)。每个链接通常在第一个报文段中指明这个选项。
TCP报文的数据部分是可选的。