博客
关于我
TCP三次握手,四次挥手过程
阅读量:329 次
发布时间:2019-03-04

本文共 897 字,大约阅读时间需要 2 分钟。

ACK:
TCP
格式中的控制位由6个标志比特构成,其中一个就是ACK,ACK为1表示确认号有效,表示发来的数据已确认接收无误。为0表示报文中不包含确认信息,忽略确认号字段。
暂时需要的信息有:
ACK
 : TCP协议规定,只有ACK=1时有效,也规定连接建立后所有发送的报文的ACK必须为1
SYN
(SYNchronization) : 在连接建立时用来同步序号。当SYN=1而ACK=0时,表明这是一个连接请求报文。对方若同意建立连接,则应在响应报文中使SYN=1和ACK=1. 因此,  SYN置1就表示这是一个连接请求或连接接受报文。
FIN 
(finis)即完,终结的意思, 用来释放一个连接。当 FIN = 1 时,表明此报文段的发送方的数据已经发送完毕,并要求释放连接。
三次握手过程
一,TCP规定,SYN = 0时,是不能携带数据的,但要消耗一个序号,因此声明自己的序号为seq= x;
二,服务器收到请求后,会回复客户端ACK报文,并开始分配连接资源。
三,客户端再次发送报文确认后,客户端开始分配连接资源。这时就不需要SYN了。然后就建立连接
四次挥手过程
一,client 向 server 发送 FIN 报文,表示 “
我已经没有数据再发过来了,但如果你还有数据要发给我,
你可以继续发。”
二,当server 收到后,因为不确定自己的数据发完了没有,所以会先发一个 ACK 报文,表示“
我收到了
你的 FIN 报文,但我还没准备好,请你继续等我消息”
此时,client 会进入 FIN_WAIT 状态。等待
server 的FIN 报文
三,当server 确认已经发完数据后,会向 client 发送 FIN 报文,告诉client “好了,我已经准备好了,
可以准备关闭 连接了”
四,当 client 收到 FIN 报文后,会发送 ACK报文给 server,告诉 server现在就可以关闭连接。
然后 client 会进入 TIIME_WAIT 状态,等待2MSL 后,依然没有收到回复,
证明 server
已经关闭了,那我client 也可以关闭了
你可能感兴趣的文章
mysql索引
查看>>
mysql索引
查看>>
Mysql索引,索引的优化,如何避免索引失效案例
查看>>
Mysql索引、命令重点介绍
查看>>
mysql索引、索引优化(这一篇包括所有)
查看>>
Mysql索引一篇就够了
查看>>
MySQL索引一篇带你彻底搞懂(一次讲清实现原理加优化实战,面试必问)
查看>>
MySQL索引下沉:提升查询性能的隐藏秘
查看>>
MySql索引为什么使用B+树
查看>>
MySQL索引为什么是B+树
查看>>
WARNING!VisualDDK wizard was unable to find any DDK/WDK installed on your system.
查看>>
MySQL索引介绍及百万数据SQL优化实践总结
查看>>
Mysql索引优化
查看>>
MySQl索引创建
查看>>
mysql索引创建及使用注意事项
查看>>
mysql索引创建和使用注意事项
查看>>