💡 TCP/IP(Transmission Control Protocol/Internet Protocol,传输控制协议/网际协议)是指能够在多个不同网络间实现信息传输的协议簇。TCP/IP协议不仅仅指的是TCP 和IP两个协议,而是指一个由FTP、SMTP、TCP、UDP、IP等协议构成的协议簇, 只是因为在TCP/IP协议中TCP协议和IP协议最具代表性,所以被称为TCP/IP协议。
TCP/IP分层管理
TCP/IP协议族按层次分可以分为以下四层。
应用层-传输层-网络层-数据链路层
TCP/IP分层的好处是可以解耦,如果互联网只由一个协议统筹,某个地方需要改变设计时,需要把整体都替换掉,而分层之后只需要把变动的层替换掉即可。
TCP/IP通信传输流
利用TCP/IP协议簇进行通信时,会通过分层顺序与对方进行确认,下面我们用HTTP来举例说明一下。
- 客户端作为发送端在应用层使用HTTP协议向某一个web页面发送请求。
- 为了传输方便,在传输层(TCP协议)把从应用层接收到的数据(HTTP请求报文)进行分割,并在各个报文上打上标记序号及端口号后转发给网络层。
- 在网络层(IP协议),增加作为通信地址的MAC地址然后转发给数据链路层。
当接收端的服务器在链路层收到数据,按序往上层发送,一直到应用层,才算能真正接收到客户端发来的HTTP请求。
发送端在层与层之间传输数据时,每经过一层必定会被打上该层所属的首部信息。反之,接收端在层与层传输数据时,每经过一层必会把对应的首部消除。
TCP三次握手
最开始的时候客户端和服务端都是处于CLOSED状态,主动打开的是客户端,被动打开的是服务端。
- TCP服务器先创建传输控制块TCB,时刻准备接受客户进程的连接请求,此时服务器就进入了LISTEN状态;
- TCP客户进程也是先创建传输控制块TCB,然后向服务器发出连接请求报文,这是报文首部中的同步为SYN=1,同时选择一个初始序列号seq=x,此时客户端进程进入了SYN-SENT(同步到已发送)状态。TCP规定,SYN报文段(SYN=1的报文段)不能携带数据,但需要消耗掉一个序号。
- TCP服务器收到请求报文后,如果同意连接,则发出确认报文。确认报文中应该ACK=1,SYN=1,确认号是ack=x+1,同时也要初始化一个序列号seq=y,此时TCP服务器进程进入了SYN-RCVD状态。这个报文也不能携带数据,但是同样要消耗一个序号。
- TCP客户端收到确认后,还要向服务器给出确认。确认报文的ACK=1,ack=y+1,自己的序列号seq=x+1,此时TCP连接建立,客户端进入ESTABLISHED(已建立连接)状态。TCP规定,ACK报文段可以携带数据,但是如果不携带数据则不消耗信号。
- 当服务器收到客户端的确认后也进入ESTABLISHED状态,此时双方就可以开始通信了。
为什么TCP客户端最后还要发送一次确认呢?
主要防止已经失效的连接请求报文突然又传送到了服务器,从而产生错误。
TCP的释放-四次挥手
数据传输完毕后,双方都可释放连接。最开始的时候,客户端和服务器都是处于ESTABLISHED状态,然后客户端主动关闭,服务器被动关闭。