博客
关于我
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 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>