TCP三次握手四次挥手的原因
来源:互联网 发布:沈航网络自助平台套餐 编辑:程序博客网 时间:2024/06/05 19:10
连接建立阶段,三次握手:
为什么不是一次?
因为TCP是有链接的,就像打电话,A拨号给B,要B选择接听以后才能进行通信,故第二次握手是发送B同意的信号。
为什么不是两次?
因为网络传输是不可靠的,存在B发回的确认帧丢失的情况。如果这个包丢失了,那么A会认为和B没连上,超时重传一个连接信号;而B,则因认为A已经和自己建立好连接了,无视这个包。那么A、B之间永远连不上了。
为什么B不对A发回的确认帧进行再确认?
不需要,因为建立连接是A先提出的,所以它有消息要发送给B,这份消息会在A发回确认帧时带给B,因此进入了消息传输阶段。而B的这份确认会在消息传输阶段进行,A没收到确认帧,则会重传消息。
为什么不是四次?
如果是四次握手,那么流程是两次握手的全双工版: A和B建立连接,B回应,表示知道了;B和A建立连接,A回应,表示知道了。显然第二步和第三步可以合并为三次握手。
连接建立过程:
第一次握手:主机A发送位码为syn=1,随机产生seq number=1234567的数据包到服务器;主机B由SYN=1知道,A要求建立连接;
第二次握手:主机B收到请求后要确认联机信息,向A发送ack number=(主机A的seq+1),syn=1,ack=1,随机产生seq=7654321的包;
第三次握手:主机A收到后检查ack number是否正确,即第一次发送的seq number+1,以及位码ack是否为1,若正确,主机A会再发送ack number=(主机B的seq+1),ack=1,主机B收到后确认seq值与ack=1则连接建立成功。
完成三次握手,主机A与主机B开始传送数据。
连接关闭阶段,四次挥手:
为什么是四次?因为TCP是全双工的通信模式,三次握手达到的其实是四次握手的效果。A单方面想关闭和B的通信渠道,只表示A不想给B发消息了;只有当B也不想给A发以后,连接才能真正的关闭。
阅读全文
0 0
- TCP三次握手四次挥手的原因
- tcp三次握手,四次挥手的原因
- TCP三次握手四次挥手的原因
- TCP三次握手与四次挥手的过程及原因
- TCP三次握手与四次挥手的过程以及原因
- TCP的三次握手和四次挥手
- TCP的三次握手和四次挥手
- TCP三次握手/四次挥手的作用
- TCP的三次握手四次挥手
- TCP的三次握手/四次挥手
- TCP的三次握手/四次挥手
- TCP的三次握手,四次挥手
- TCP的三次握手/四次挥手
- TCP的三次握手、四次挥手
- TCP的三次握手/四次挥手
- TCP的三次握手和四次挥手
- TCP的三次握手和四次挥手
- TCP连接的三次握手,四次挥手
- Laravel5.4快速开发简书网站
- 牛客网--链表反转打印
- 常见智力题总结
- 2.5类型别名,auto, decltype
- Coursera 《Machine Learning》 编程作业7:K-means聚类和主成分分析
- TCP三次握手四次挥手的原因
- React的事件处理函数
- 2017年腾讯实习生在线笔试编程题(1)
- 常见IO模型
- jQuery.lazyload详解
- python(三)6种排序算法性能比较(冒泡、选择、插入、希尔、快速、归并)
- Struts tiles入门(最最简单的例子)
- 51nod 1391 01串
- 文化传统的变迁·《这世界,原该天清地宁》