TCP是面向连接的(connection-oriented),即收发双方在发送数据之前,必须首先建立一个连接,这样在连接断开之前,就一直使用这个连接传输数据。建立连接包括参数的设置、内存空间的分配,收发双方参数的协商等,这一过程需要经过三次成功的沟通,一般叫做“三次握手” (a three-way handshake)。
用通俗的话来讲,这三次沟通就是:
- 发起方:“你好,请问我可以跟你建立一个连接吗?”(发送请求,等待回复)
- 接收方:“好啊,我准备好了,来吧。”
- 发起方:“好的,谢谢,我现在开始向你发送数据了。”
当然,在具体的实现过程中,还包含许多细节,以下一一阐述。
1. TCP报文段结构
要了解三次握手的过程中发送了什么报文,首先得知道TCP报文段由哪些字段构成,其中哪些字段在这个过程中起了关键作用。
我们重点关注以下几个字段:
- Sequence number:序列号,用来标记一个报文段的序号,报文段首字节的字节流编号
- Acknowledgment number:确认号,只有ACK标志位为1时,确认序号字段才有效
- ACK:用于指示确认号是有效的
- SYN: