TCP最主要的特点
1、TCP是面向连接的运输层协议。( 每一条TCP连接只能有两个端点(endpoint),每一条TCP连接只能是点对点的(一对一))
2、TCP提供可靠交付的服务。
3、TCP提供全双工通信。
4、面向字节流。
TCP中的“流”(stream)指的是流入或流出进程的字节序列。
面向字节流:虽然应用程序和TCP的交互是一次一个数据块,但TCP把应用程序交下来的数据看成仅仅是一连串无结构的字节流。
(服务器,端口,socket--相当于电源,插排,插排口)
socket有多种不同的意思:
应用编程接口 API 称为socket API, 简称为socket;
socket API 中使用的一个函数名也叫socket;
调用socket函数的端点称为socket;
调用socket函数时其返回值称为socket描述符,可简称为socket。
TCP是如何实现可靠传输的
1、每发送完一个分组就停止发送,等待对方的确认。在收到确认信息后在发送下一个分组;
2、全双工通信的双方既是发送方也是接收方;
3、假设仅考虑 A 发送数据, 而 B 接受数据并发送确认信息。因此 A 叫做发送方,而 B 叫做接收方;
A 如何知道 B 是否正确收到了 M1 呢?
解决方法:超时重传
A 为每一个已发送的分组设置一个超时计时器。
A 只要在超时计时器到期之前收到了相应的确认,就撤销该超时计时器,继续发送下一个分组 M2
若 A 在超时计时器规定时间内没有收到 B 的确认,就认为分组错误或丢失,就重发该分组。
机制1: 确认丢失
若 B 所发送的对 M1 的确认丢失了,那么 A 在设定的超时重传时间内将不会收到确认,因此 A 在超时计时器到期后重传 M1。
假定 B 正确收到了 A 重传的分组 M1。这时 B 应采取两个行动:
(1) 丢弃这个重复的分组 M1,不向上层交付。
(2) 向 A 发送确认。
机制2:确认迟到
B 对分组 M1 的确认迟到了,因此 A 在超时计时器到期后重传 M1。
B 会收到重复的 M1,丢弃重复的 M1,并重传确认分组。
A 会收到重复的确认。对重复的确认的处理:丢弃。
提高传输效率:流水线传输
连续 ARQ 协议
发送窗口:发送方维持一个发送窗口,位于发送窗口内的分组都可被连续发送出去,而不需要等待对方的确认。
发送窗口滑动:发送方每收到一个确认,就把发送窗口向前滑动一个分组的位置。
累积确认:接收方对按序到达的最后一个分组发送确认,表示:到这个分组为止的所有分组都已正确收到了。
TCP报文段的首部格式