看图理解TCP的三次握手和四次挥手

阅读时间:8min
阅读目标:服务器

  1. 掌握TCP链接过程
  2. 学会计算seq、ack码

TCP 协议是HTTP协议的重要基础,充分理解TCP协议的链接及端口,有助于咱们深刻理解网络请求和链接。今天就来看图学习TCP请求的链接、数据传输及端口链接。网络


OSI7层网络模型

OSI是 Open System Interconnection的缩写,国际标准化组织(ISO)制定了OSI模型,该模型定义了不一样计算机互联的标准,是设计和描述计算机网络通讯的基本框架。
参考模型(从上至下) 各层含义
应用层 为应用程序提供服务,如HTTP、FTP、SMTP、POP3等
表示层 数据格式转换翻译、数据加密解密、压缩解压缩
会话层 不一样机器之间的用户创建及管理会话
传输层 创建管理和维护端到端的链接,TCP、UDP
网络层 IP地址及路由选择
数据链路层 物理寻址,将原始比特流转化为逻辑传输线路
物理层 机械、电子、定时接口通讯信道上上的原始比特流传输

1. 传输层

接受上一次的数据,将数据进行分割,保证数据准确到达对端。

2. TCP

TCP是面向链接的无状态的协议。为了链接的可靠性,每次链接的创建都须要3次握手。

2.1 创建链接(3次握手)

3次握手的目的:并发

  1. 同步链接双方的序列号和确认号;
  2. 交换TCP窗口大小信息。
客户端(状态) 创建链接(三次握手) 服务端(状态)
CLOSED LISTEN
SYN seq=0 ==》
SYN_SENT
《== SYN ACK ack=1,seq=0
SYN_RCVD
ACK ack=1,seq=1 ==》
ESTABLISHED ESTABLISHED
  • 第一次握手: 创建链接。客户端发送链接请求,发送SYN报文,随机生成seq,本例默认为0。而后,客户端进入SYN_SEND状态,等待服务器的确认。
  • 第二次握手: 服务器收到客户端的SYN报文段。须要对这个SYN报文段进行确认,发送ACK报文,将ack设置为1(ack值为对方seq+1或者seq+L(数据长度L))。同时,本身还要发送SYN请求信息,将seq为0。服务器端将上述全部信息一并发送给客户端,此时服务器进入SYN_RECV状态。
  • 第三次握手: 客户端收到服务器的ACK和SYN报文后,进行确认,而后将ack设置为1,seq设置为1,向服务器发送ACK报文段,这个报文段发送完毕之后,客户端和服务器端都进入ESTABLISHED状态,完成TCP三次握手。

2.2 数据传输

客户端 数据传输 服务端
PSH seq=1, ACK ack=1(segmentLen = 99) ==》
《== PSH seq=1, ACK ack=100 (segmentLen = 119)
ACK ack=120,seq=100 ==》
  • 客户端先向服务器发送数据,该数据报是长度为99的数据。
  • 服务器收到报文后, 也向客户端发送了一个数据进行确认(ACK),而且返回客户端要请求的数据,数据的长度为111,将seq设置为1,ack设置为120(1 + 119)。
  • 客户端收到服务器返回的数据后进行确认(ACK),将seq设置为100, ack设置为112(1 + 111)。

2.3 断开连接(4次挥手)

客户端(状态) 断开链接 服务端(状态)
FIN ACK ack=120,seq=100 ==》
FIN_WAIT_1
《== ACK ack=101,seq=120
FIN_WAIT_2 CLOSE_WAIT
《== ACK ack=101,seq=120
LAST_ACK
ACK ack=121,seq=101 ==》
TIME_WAIT CLOSE
  • 第一次挥手:客户端向服务器发送一个FIN报文段,将设置seq为100和ack为120,;此时,客户端进入 FIN_WAIT_1状态,这表示客户端没有数据要发送服务器了,请求关闭链接;
  • 第二次挥手:服务器收到了客户端发送的FIN报文段,向客户端回一个ACK报文段,ack设置为101,seq设置为120;服务器进入了CLOSE_WAIT状态,客户端收到服务器返回的ACK报文后,进入FIN_WAIT_2状态;
  • 第三次挥手:服务器会观察本身是否还有数据没有发送给客户端,若是有,先把数据发送给客户端,再发送FIN报文;若是没有,那么服务器直接发送FIN报文给客户端。请求关闭链接,同时服务器进入LAST_ACK状态;
  • 第四次挥手:客户端收到服务器发送的FIN报文段,向服务器发送ACK报文段,将seq设置为101,将ack设置为121,而后客户端进入TIME_WAIT状态;服务器收到客户端的ACK报文段之后,就关闭链接;此时,客户端等待2MSL后依然没有收到回复,则证实Server端已正常关闭,客户端也能够关闭链接了。
计算规则: seq 为序列号 ack 为应答码 seq = 对方上次的ack;(首次发送时seq为系统随机生成) ack = 对方的seq+1(无数据传输时) 或者 seq+L(报文数据的长度L)
相关文章
相关标签/搜索