博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TCP协议的三次握手和四次挥手
阅读量:6307 次
发布时间:2019-06-22

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

             TCP协议的三次握手和四次挥手

我们知道,TCP是主机对主机层的传输控制协议,提供可靠的连接服务,需要三次握手建立连接,而终止一个连接要经过四次挥手。

三次握手

第一次握手:客户端申请连接(SYN=1),发送seq=x的数据包,等待服务器确认。

第二次握手:服务器端申请连接(SYN=1),确认收到客户端的申请(ACK=1).;服务器期望下次收到x+1数据包(ack=x+1),发送seq=y的数据包。
第三次握手:客户端确认收到请求(SYN=1),发送服务器期望的数据包(y+1),完成连接。
TCP协议的三次握手和四次挥手

四次挥手

第一次挥手:客户端请求断开连接(FIN=1),发送数据(seq=u)。

第二次挥手:确认收到请求(ACK=1),期望收到数据包(ack=u+1),发送数据(seq=v)。
第三次挥手:服务器申请断开连接(FIN=1),确认收到你之前的请求(ACK=1);期望收到数据(ack=u+1),发送数据(seq=w)。
第四次挥手:确认收到请求(ACK=1),发送数据(seq=u+1),断开连接。
TCP协议的三次握手和四次挥手

为什么需要三次握手?

   如果不采用“三次握手”,那么只要服务器发出确认,新的连接就建立了。由于现在客户端并没有发出建立连接的请求,因此不会理睬服务器的确认,也不会向服务器发送ACK包,但是服务端确认为新的连接开始了,等待客户端发数据,这样就会白白浪费资源。而经过三次握手,客户端和服务器都有应有答,这样可以确保TCP正确连接。

为什么需要四次挥手?

  在TCP建立连接时,服务器端的SYN和ACK向客户端发送是一次性发送的,而在断开连接的过程中,服务器端向客户端端发送的ACK和FIN是是分两次发送的。因为在服务器端接收到客户端的FIN后,客户端可能还有数据要传输,所以先发送ACK,等客户端处理完自己的事情后就可以发送FIN断开连接了。

为什么四次挥手后有2MSL的时间等待?

   MSL(Maximum Segment Lifetime),最大报文段生存时间,2个MSL是报文段发送和接收的最长时间。假定网络不可靠,那么第四次发送的ACK可能丢失,即服务器端无法收到这个ACK,如果服务器端收不到这个确认ACK,服务器端会定时向客户端重复发送FIN,直到服务器端收到客户端的确认ACK。所以这个2MSL就是用来处理这个可能丢失的ACK的。

转载于:https://blog.51cto.com/13570220/2088222

你可能感兴趣的文章
css定位概述
查看>>
C# 动态修改配置文件 (二)
查看>>
BOM:文档对象模型 --树模型
查看>>
我的Android进阶之旅------>WindowManager.LayoutParams介绍
查看>>
segment
查看>>
获取鼠标的原始移动值
查看>>
Linux信号 编程
查看>>
有关滚动与位置
查看>>
Box2D自定义重力
查看>>
chpasswd
查看>>
mysqldump --single-transaction 和--lock-tables参数详解
查看>>
android 数据库_sql语句总结
查看>>
python购物车
查看>>
解决python2和python3的pip冲突
查看>>
面试/编程
查看>>
linux每日命令(16):head命令
查看>>
公司内部分享【富有成效的每日站会】总结
查看>>
打造一个上传图片到图床利器的插件(Mac版 开源)
查看>>
iOS横竖屏
查看>>
thinkphp判断更新是否成功
查看>>